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FOREWORD 



« This manual provides the user with all the information necessary to 
write symbolic programs in the 70/l5 Assembly Language. The instruc- 
tions for assembling these programs, in preparation for subsequent execu- 
tion on the RCA 70/15 Processor, are included. In addition, a section on 
the Input-Output Control System (IOCS) is provided. This I/O system re- 
duces and simplifies the coding required for control of input/output opera- 
tions. The I/O section has been incorporated into this manual so that it 
may serve as a single source for all symbolic programming references. 

It is assumed that the reader is familiar with the RCA 70/15 Processor. 
A complete description can be found in the RCA 70/15 Processor Refer- 
ence Manual (No. 70-15-601). 
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INTRODUCTION 



FEATURES 

Operation Code 
Mnemonics 



Symbolic Addressing 



Expressions 



External References 



♦ The 70/15 Assembly System translates a symbolic machine-oriented 
source language program into a computer-recognizable object program. 
The Assembler assists the programmer by reducing the amount of com- 
plex details required to code in machine language and, as a result, in- 
creases the efficiency of the programmer. Source language input and 
object program output may be punched on cards or stored on magnetic tape. 
The Assembler produces an output listing of both the source and object codes. 

♦ Several of the Assembler features are summarized below. 

♦ Each machine instruction is assigned a unique mnemonic operation code 
as specified in the assembly language. The programmer uses these 
mnemonics instead of the less readable binary -bit configurations to specify 
the desired instructions. 

♦ Every memory location is available for assignment as a symbolic name 
for program reference. This symbolic name allows reference to branch 
points , tables , constants , and storage areas without requiring knowledge 
of absolute memory addresses which will subsequently be assigned by the 
Assembler. 

♦ The Assembler provides the ability to combine symbols and numeric 
values to form desired addresses. For example, relative addressing is a 
feature of the assembler where items in the program are addressed rela- 
tive to a defined symbol; i.e., an incremental or a decremental value rela- 
tive to a symbolic name. 

♦ The Assembler enables a program or a subprogram to reference data 
and/or control information outside its boundaries. This feature is pro- 
vided via a unique program symbolic name that represents the desired 
reference. Thus, separately assembled subprograms may be linked to- 
gether at execution time. 

In addition to these features, the Assembler also has provisions for 
permitting subsequent object program relocation and appropriate error 
checking of source programs with associated warning flags. 



SYSTEM 
REQUIREMENTS 

EQUIPMENT 
REQUIREMENTS 



RELATED 

PROGRAMMING 

SYSTEMS 



♦ Minimum Equipment 
Processor 1 

Card Reader 1 



Card Punch 
Printer 



70/15A*, 70/15B** 

70/237 or 70/251 with any punched card read 
feature 

70/234, 70/236 

70/242, 70/243 



Optional Equipment 

Processor* 1 70/15B 

Magnetic Tapes** 70/432, 70/442, 70/445 

♦ The following loaders are provided for loading the 70/15 Assembly 
System into memory: 

Card System - 70/15 Loader AA (Absolute) 

Tape Library System - 70/15 Loader AT (Absolute/PLT) 

The 70/15 Tape Assembly System is designed around the utilization of 
device interchangeability. Even though the system is card oriented, mag- 
netic tapes may be substituted for any of the following: 



Assembler Program 
Source Input 
Second Pass Input 



Object Program Listing 
Object Program Deck 



The I/O commands within the 70/15 Assembler reference the different 
peripheral devices as logical devices. The logical devices are linked with 
the actual devices at load time by the loaders. I/O Define cards (see page 
53 for format description)must be included with the Loader and the Assem- 
bler at load time in order to accomplish this linkage. The I/O Define cards 
specify, among other things, where a device is to be found (trunk and unit 
number) and what type of device is to be found there (card reader, punch, 
etc.). For each of the following logical device numbers, an I/O Define 
card must be supplied at load time: 



00 - Input Device for Pass 1 08 

01 - Input Device for Pass 2 09 



Object Program Output Device 
Assembly Listing Device 



Through this feature, it is readily seen that magnetic tape(s) may be 
designated for any or all of the above functions. 



* Card Assembly System 
** Tape Assembly System 



ASSEMBLY 

STATEMENT 

FORMATS 



GENERAL 
CONSIDERATIONS 



♦ The 70/15 Assembly System translates symbolic machine-oriented 
source language programs into machine language programs. The source 
language program must conform to certain conventions, one of which is 
the assembly statement format. The assembly statements are written on 
RCA SPECTRA 70 coding forms (Figure 1) and occupy columns 1-71. Col- 
umn 72 is imavailabletothe programmer and columns 73-80 are available 
for both the program identification and statement sequencing. 

A statement consists of from one to four fields. These are: the Name 
field, the Operation field, the Operand field, and the Comments field. 
(The Identification-Sequence field is explained on page 12.) The statement 
fields are written onthe RCA SPECTRA 70 coding form left-justified within 
the following columns: 



Columns 


Field 


1 -4 


Name field 


5-9 


Blank 


10 - 14 


Operation field 


15 


Blank 


16 - 71 


Operand and Comments fields 


72 


Blank 


73 - 80 


ID- Sequence field 



♦ 1 . Every statement must have a machine or Assembler instruction speci- 
fied in the Operation field except when the entire statement line is 
used for comments. The other fields may or may not be used, de- 
pending on the particular instruction and the programmer's wishes. 

2. Embedded blanks must not be used within the Name or Operation 
fields. Blanks can only occur as a character constant or a self- 
defining value within the Operand field. 

3. Only one statement can be written on a coding line. A statement can 
use a maximum of 71 columns and cannot be continued onto another 
line of coding. 

4. Column 72 cannot be used by the programmer and must be left blank. 

5. When the word Blank is used in this manual in reference to the con- 
tents of a column or field, it indicates that no punch is to be made in 
that column or field. 



►<^ 



CHARGE NO. 
DATE REQ'D 




SPECTRA 70 
ASSEMBLY PROGRAM FORM 



FLOW CHART REFERENCE , 




PACE OF . 



PROGRAMMER _ 



NAME 




OPERATION 




OPERAND COMMENTS 
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Figure 1, RCA Spectra 70 Assembly Program Form 



Assembly Statement 
Formats 



RULES FOR 

CHARACTERS 

AND SYMBOLS 

Character Set 



Symbols 



Examples 



Defining Symbols 



External Symbols 



♦ The following rules govern the use of characters and symbols when 
writing Assembler Statements: 

♦ The character set for 70/15 Assembly Statements consists of the fol- 
lowing gr^hics: 



Alphabetic 

Numeric 

Special Characters 



A through Z 

through 9 

$* + -,()' BLANK 



♦ A symbol is a set of one to four characters used to name a statement 
line. The set of characters that may be used is limited to any alphabetic 
character (A through Z) or numeric character (0 through 9). In addition, 
the first character of the symbol must be alphabetic. The $ precedes 
special symbols that reference standard memory locations and may be 
used only in the Operand field of an instruction. (See page 11.) 

♦ Valid: MASK 

A12 
B 
Invalid: INPUT (too many characters) 

123 (first character not alphabetic) 

A. 2 (decimal point is not a valid character for symbol) 

♦ Symbols provide the means for referencing instructions , constants , or 
storage areas and are initially defined in the Name field of a statement. 
Normally, any symbol which is referenced is defined within the same pro- 
gram. The 70/15 Assembly System, however, permits independently 
assembled programs to reference symbols in other independently assem- 
bled programs. This is accomplished via the EXTRN and ENTRY Assem- 
bler Program Linking instructions. 

♦ As was stated above , the 70/15 Assembly System allows a programmer 
to refer to a symbol which is defined in another assembled program. This 
type of symbol is called an external symbol. Any symbol that is referred 
to by a statement in another assembled program is called an entry point. 
An entry point can, of course, also be referenced by statements within its 
own program. The programmer writes an ENTRY statement for every 
entry point, and an EXTRN statement for every external symbol. The use 
of this feature Is meaningful only when the programs are to be loaded and 
executed together. The ENTRY and EXTRN statements are described on 
pages 24 and 25 respectively. 



Assern hly Statement -s 
Formats 



Additional Restrictions 
on Symbols 



NAME Field 
(Columns 1-4) 



OPERATION Field 
(Columns 10-14) 



OPERAND Field 
(Columns 16-71) 



4 1. A symbol can be defined only once per assembly. Duplicate names 
are flagged and the first definition is used in all cases. 

2. A symbol cannot be used as a name and an external in the same as- 
sembled program. 

3. The size of the processor's main storage (4K or 8K) determines the 
maximum number of symbols that can be used in one program. In the 
Card Assembly System , the maximum number of symbols for a 4K pro- 
cessor is 90; maximum for an 8K processor is 700. The maximum 
number of symbols for the Tape Assembly System is 550. 

♦ In the Name field a symbol is used to identify a particular statement so 
that it can be referred to by another statement. A name does not have to 
be given to every statement. It should be used when the statement is to be 
referred to by another statement. 

Whenever a name is given, it must start in column 1 and extend no fur- 
ther than colunon 4. If column 1 is a blank, the assembler assumes that 
the statement has not been named. If column 1 contains an asterisk (*) , 
the entire line is considered a comment (See page 12 for the description of 
the Comments field). 

♦ A programming or Assembler mnemonic instruction is written in the 
Operation field. This field starts in column 10. Valid nmemonics vary 
from one to five characters in length. The valid programming and Assem- 
bler instructions and their mnemonics are described under "Programming 
Instructions" (page 13) and "Assembler Instructions" (page 16). A blank 
in column 10 will indicate an invalid instruction. 

The Assembler generates a Halt and Branch instruction and four zero 
bytes whenever an invalid nonemonic is specified. This allows the pro- 
grammer to patch any size instruction in the area without resorting to a 
separate patch area. The statement is also flagged as an error. 

♦ The Operand field defines the locations, data, or device which are used 
by the Operation field. The Operand field must begin in column 16. In 
machine instructions , it is used to specify the second through sixth bytes 
of the instruction. The format of the Operand field for an Assembler in- 
struction varies according to the requirements of the machine instruction. 

The Operand field is divided into subfields . Each subfield is itself called 
an operand. The number of these operands depends on the instruction. 

Commas are used to separate operands within a statement. It should 
be remembered that blanks cannot be written within a particular operand 
or between operands. When a blank is detected, it immediately terminates 
the Operand field and the remaining information is treated as a comment. 
If the Operand field is incomplete, the statement is flagged as an error on 
the assembly listing. 



Assembly Statement 
Formats 



OPERAND Field 
(Cont'd) 



Defining Operands 



The Location Counter 



The most common Operand field format uses two operands. Each of 
these operands represents the locations in memory that are to be used in 
the execution of this instruction. For additional information concerning 
the examples given in the following sections, refer to the programming 
instruction formats (page 13). 

♦ The Operand field defines locations, data and lengths of data, or devices 
which are used by the Operation field. The following sections describe the 
methods by which operands may be defined in the assembly language. How- 
ever, a description of the Location Counter and its fimction is useful at 
this point. 

♦ The Assembler assigns locations to those statements which use or re- 
serve memory areas. The Assembler keeps a counter, called the Location 
Counter, to facilitate the handling of the location assignment. The Assem- 
bler normally assigns consecutive locations to statements. (The START 
and ORG Assembler instructions (See description under Programming 
Instructions, page 16) allow the programmer to set and reset the location 
counter respectively. ) The Location Counter is incremented by the num- 
ber of bytes required by a statement after the analysis of the statement. 
The Location Counter is then pointed at the leftmost available memory 
byte. Statements that are given symbolic names have their names associ- 
ated with the Location Coimter setting of the leftmost byte of the field re- 
quired by the statement. This is then stored in a table and, when the 
statement is subsequently referenced by its name in the Operand field of 
another statement, the associated memory location is placed in the Operand 
field of the generated-machuie instruction. 

Location Counter Overflow. The Assembler normally compiles programs 
for a 4K or 8K memory. The Location Counter can maintain addresses up 
to 65K. However, the Assembler flags any statement which sets the Loca- 
tion Coimter above the limit of the available memory of the processor. 
The statement, nevertheless, will be processed with the excess location 
Counter value. 



Program References. The programmer can specify the current value of 

the Location Coimter as an address by writing an asterisk (*) at the ap- 
propriate point in the Operand field. This is an alternative to naming the 
statement and then using this name in the Operand field. The programmer 
can specify relative addressing after the asterisk. The programmer should 
note that the location referred to is the leftmost byte of the statement. 
Chart 1. Example of Program Referencing Using the Location Counter 
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Assembly Statement 
Formats 



Relative Addressing 



^ Using Location Counter. The programmer may assign an address value 
to an operand that will be relative to the current value of the location 
counter. This is done by writing an asterisk (*) at the appropriate point 
in an Operand field. The programmer can then specify an address which 
is equal to, greater, or less than the current Location Counter value. The 
address assigned will be based on the leftmost byte location of the current 
statement. The plus sign (+) is used for addition and the minus sign (-) is 
used for subtraction. (See Chart 2.) 

Using Symbols. Any symbol (statement name) can have an amoimt added 
or subtracted from it. As in relative addressing using the current Loca- 
tion Counter value, the plus sign (+) is used for addition and the minus 
sign (-) for subtraction. The amount of relative addressing is expressed 
by a self -defined value. The value of the relative address always repre- 
sents the number of bytes. (See Chart 3. ) 



Chart 2. Example of Relative Addressing Using Location Counter 
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Chart 3. Example of Relative Addressing Using Symbols 
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Assembly Statement 
Formats 



Self-Defining Values 



Decimal 



Hexadecimal 



♦ Self-defining values define: relative addresses, operand length, I/O 
information, and masks to the Assembler. They also provide an alterna- 
tive method of defining storage addresses. They are converted by the 
Assembler to their binary equivalents. 

The Assembler accepts three types of self-defining values: decimal, 
hexadecimal, and character. The programmer may choose any type he 
desires. 

4 An unsigned decimal number can be used to further define an operand. 
The value is one to four decimal -digits. The Assembler converts this 
value to its binary equivalent. The length of this binary value depends on 
the format of the generated-machine instructions . The number must be 
represented by the set of digits zero (0) through nine (9) . A value of more 
than four digits will be truncated and flagged in the Assembler listing. 
The excess high-order or leftmost characters will be dropped. (See 
Chart 4.) 



Parentheses used in Chart 4 are required by the instruction format, 
description under "Programming Instructions" (page 13). 



See 



♦ A hexadecimal value is defined by writing the letter X followed by the 
hexadecimal digits enclosed in single quotation marks. The value can 
consist of from one to four hexadecimal digits. A self-defined hexadeci- 
mal value of more than four digits is truncated at four digits and flagged 
in the Assembler listing. The low-order or rightmost characters are 
dropped. The decimal digits zero (0) through nine (9) and the alphabetic 
characters A through F are the valid hexadecimal digits. Any invalid 
character results in an error flag. The equivalent four-bit binary value 
for each of the valid hexadecimal digits is shown on page 10. 
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Assembly Statement 
Formats 



Hexadecimal 
(Cont'd) 



Character 



Hexadecimal Digit 



1 

2 

3 

4 

5 

6 

7 

8 

9 

A 

B 

C 

D 

E 

F 



Four-Bit Binary Value 

0000 
0001 
0010 
0011 
0100 
0101 
Olio 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

1111 



Chart 5 shows examples of hexadecimal self -defining values. 

Note that the maximum of four digits refers to self-defined values and not 
to a constant defined by a DC (Define Constant) See page 20. 

4 A character value is defined by writing the character C followed by a 
single character enclosed in single quotation marks. (See Chart 6.) The 
character canbe any ofthe 256 combinations available in an eight -bit format. 
The Assembler assumes that the character is pimched in the Extended Binary- 
Coded Decimal Interchange Code (EBCDIC). The self-defined character 
value ' (single quotation mark) is written as two consecutive quotation 
marks within the beginning and ending single quotation marks (e.g., C""). 



Chart 5. Examples of Hexadecimal Self-Defining Values 
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Chart 6. Example of Character Self-Defining Value 
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Assembly Statement 
Formats 



Relocatable Operands 



Standard Memory 
Locations 



Special 
Symbol 


Location 


$P 


130 


$L 


200 


$LS 


196 



♦ The 70/15 Assembly System, along with its normal function of generating 
machine code from source code , provides all the necessary control informa- 
tion which would permit a program to be relocated. Provided that a relo- 
catable loader is used, all operands may be relocated with the exception of 
the following: 

1. Self-defining values used to define absolute machine addresses. 

2 . Hexadecimal or character constants (see page 20 , Defining Constants). 

O. «PP) *Pl-') *Pi-*& 

♦ The following special symbols may be used to reference certain stand- 
ard memory locations. They must be used in the operand field of an in- 
struction and must be immediately preceded by a dollar sign ($). 



Significance 

MSB* of subroutine parameter 

MSB of Branch to Loader 

MSB of Branch to instruction fol- 
lowing the loader read logic. 



*MSB - Most Significant Byte 

1. $P is the MSB of the standard memory locations which are utilized 

for communication between a program and a subroutine. The 
length of this area is 16 bytes and may be used by any program 
which desires to pass on parameter information to a subroutine. 
See "Input/Output Control System," for an example of its use. 

2. $L is the MSB of an instruction which branches to the Loader. Pro- 

duction runs may be stacked and executed one at a time. This 
may be accomplished by requiring that each program execute a 
Halt and Branch to $L as its last instruction. The halt gives the 
operator time to perform such functions as dismounting and 
mounting tapes , etc . To execute the next program , all that the 
operator need do is depress the START button. 

3. $LS is the MSB of an instruction which branches to the instruction 

following the loader read logic. This feature permits a program 
to call in another program without having the Loader read from 
the input parameter device. The initiating program accomplishes 
this by moving a card image of a Loader call card into the Loader's 
input read area and then branching to $LS. Therefore, a program 
may, based on some condition, decide to call in one program in- 
stead of another. The programs to be called, are, of course, 
assumed to be on a program library tape. 
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Assembly Statement 
Formats 



COMMENTS Field 



IDENTIFICATION - 

Sequence Field 

(Column 73-80) 



♦ The programmer can write descriptive comments within the program 
statement. They are allowed strictly for documentation purposes and 
they do not have any effect on the object program. 

A Comments field can be specified in one of two ways. The primary pro- 
cedure is to write a comment to the right of the operand field. At least 
one column to the right of the last operand must be blank. In addition, the 
entire statement line can be used for comments if an asterisk (*) is written 
in the first column (Column 1). 

Comments must end in column 71 . A second card with an asterisk in 
column 1 may be used to continue the comments . 

♦ The Identification - Sequence field is available for both program identi- 
fication and statement sequencing. Columns 73-80 are reserved for these 
functions. The Assembler does not perform a sequence check on these 
columns. The first four characters (columns 73-76) are used by the As- 
sembler. When written into the Start card, they are used as the name 
assigned to the Identification field produced for the object program. The 
last four characters (columns 77-80) are used as the start of the sequence 
counter. If they are not numeric, the Assembler ignores them and sets 
its sequence counter to all zeros. Every assembled instruction card will 
have its sequence number derived from the sequence counter set by the 
START card. 
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PROGRAMMING 
INSTRUCTIONS 



ASSEMBLY/ 

MACHINE 

CODE FORMATS 



♦ The 70/15 Assembly Language provides the means for symbolically 
representing all machine instructions. The symbolic format of these in- 
structions varies according to their machine formats. 

Machine instructions are aligned by the Assembler on even-byte bound- 
aries. Any byte that is skipped will be set to zero. 

A name or sjmibol can be given to any programming instruction and any 
other statement may reference this symbol. The address value given to 
the symbol is the address of the leftmost byte of the assembled machine 
code. The length or number of bytes of each instruction can be determined 
from the machine format. 

The length subfields (L, Lj, L2), expressed within the symbolic in- 
structions , are always one more than the count subfield of the machine 
instruction, as defined in the 70/15 Processor Reference Manual. The 
symbolic representation will be the conventional decimal count. For ex- 
ample, a three-character Move will have a symbolic coimt of three. 

♦ Table 1 illustrates the basic machine formats , the instructions associ- 
ated with these formats , and the format of the applicable Operand field. 
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Assembler Operand 
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WR, WRA, WRC, 
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8 
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70/16 PTogTamming 
Instructions 



LIST OF 
INSTRUCTIONS 



♦ Table 2 is a listing of the instructions in order by instruction name. 
The column headings of the table and their definition are described below. 



Instruction Name: 
Mnemonic Op: 

Machine Code: 

Length in Bytes: 

Operand Field Format: 

Example: 



This colunm gives the name of the instruction. 

This column gives the mnemonic operation code 
for this instruction. 

This column gives the hexadecimal representa- 
tion of the actual machine operation code. 

This column gives the actual length in bytes of 
this instruction. 

This column gives the symbolic format of the 
operand field for this instruction. 

This column gives an example of the operand 
field format in Assembler language. 
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70/15 Programming 
Instructions 





Table 2. 70/15 Instructions 




Instruction 
Name 


Mnemonic 
Op 


Machine 
Code 


Length 

In 
Bytes 


Operand Field 
Format 


Example 


Add Binary 


AB 


F6 


6 


Si(Li), S2(L2) 


SUM(2), ADD(2) 


Add Decimal 


AP 


FA 


6 


Si(Li), S2(L2) 


SUM(2), ADD(l) 


Logical And 


NC 


D4 


6 


Si(L) , Sa 


BCIN+1(1), NOPC 


Branch on 
Condition 


BC 


47 


4 


M, S 


X'F'.GOTO 


Compare 
Decimal 


CP 


F9 


6 


Si(Li), S2(L2) 


ABLE(3), BAKE(3) 


Compare Logical 


CLC 


D5 


6 


S^(L), 83 


ABLE(l), BAKE 


Edit 


ED 


DE 


6 


Sj(L), Sg 


MASK(2) , DATA 


Exclusive Or 


XC 


D7 


6 


Si(L), S2 


NUM(2), ONES 


Halt and Branch 


HB 


81 


4 


S, M 


$L,X'01' 


I/O Sense 


lOS 


El 


6 


T(D), S^,S2 


1(1), FRST, LAST 


Move 


MVC 


D2 


6 


Si(L), S2 


TO(3) , FROM 


Logical Or 


OC 


D6 


6 


Si(L) , S2 


INTO(2),MASK 


Pack 


PACK 


F2 


6 


S^(L-^), S2(L2) 


FOUR(2) , EGHT(4) 


Post Status 


PS 


66 


4 


T(D), S 


1(1),* 


Read Auxiliary 


RDA 


C5 


6 


T(D), SpSg 


1(1), FRST, LAST 


Read Forward 


RDF 


E5 


6 


T(D), S^,S2 


1(1), FRST, LAST 


Read Reverse 


RDR 


E2 


6 


T(D), Si,S2 


1(1), FRST, LAST 


Set P2 


STP2 


82 


4 


S 


RTRN 


Subtract Binary 


SB 


F7 


6 


Si(Li). S2(L2) 


DIFF(2) , SUB{1) 


Subtract Decimal 


SP 


FB 


6 


S,(L^), S2(L2) 


DIFF(1),SUB(1) 


Test Under Mask 


TM 


91 


4 


S,M 


MEM.X'Fl' 


Unpack 


UNPK 


F3 


6 


Si(Li). S2(L2) 


EGHT(3),FOUR(l) 


Write 


WR 


E3 


6 


T(D), Si,S2 


2(2), FRST, LAST 


Write Auxiliary 


WRA 


C3 


6 


T(D), Si,S2 


2(2), FRST, LAST 


Write Control 


WRC 


E7 


6 


T(D), S^.Sg 


2(2), FRST, LAST 


Write Erase 


WRE 


E4 




6 


T(D), Sj.Sg 


2(2), FRST, LAST 



LEGEND 



L = 



Length (1-256) m bytes 

Length of First Field (1-16) In bytes 

Length of Second Field (1-16) in bytes 

Storage Address 

Storage Address of First Field 



^2 

M 

T 

D 



= Storage Address of Second Field 

= Mask (Self-defining value) 

= Trun!' (Self-defining value) 

= Device (Self-defining value) 
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ASSEMBLER 
INSTRUCTIONS 



ASSEMBLER 

CONTROL 

INSTRUCTIONS 

START - 
Start Program 



♦ The Assembler instructions are used to supplement the machine in- 
structions. They instruct the Assembler in the same sense that the mach- 
ine instructions instruct the machine. The Assembler instructions are 
listed below and then described in detail. 

Assembler Control Instructions 

START - Start Program 
ORG - Set Location Counter 

END - End Program 

Definition Instructions 

DS - Define Storage 

DC - Define Constant 

Program Linking Instructions 

ENTRY - Identify Entry Point 
EXTRN - Identify External Symbol 

Extended Mnemonic Instruction 

B - Branch Unconditional 

The Branch Unconditional is the only Assembler instruction to generate 
an actual machine instruction. The Start Program, Set Location Counter, 
Define Storage, and Define Constant are the only other Assembler instruc- 
tions to affect the Location Counter. 



♦ The START statement must be written as the first statement in a pro- 
gram and it must always be present. The Name field is used to name the 
program and the Operand field is used to set the Location Counter to its 
initial value. 



The format is as follows: 

NAME OPERATION 



Symbol 



START 



OPERAND 
A self-defining value 



16 



START - 

Start Program 

(Cont'd) 



Assembler 
Instructions 



♦ The symbol written in the Name field is considered to be an entry point. 
The name on the START card is entered in the Entry-Extrn table, thus 
allowing another program to refer to this program via an EXTRN state- 
ment. A name consisting of four blanks is generated if a symbol Is not 
defined in the Name field. 

A character, hexadecimal, or decimal self-defining value can be written 
in the Operand field. This value is used to set the Location Counter to its 
initial value. (See Chart 7.) Thus the START Assembler instruction serves 
as an ENTRY and ORG verb as well as signalling the first line of an assembly. 
The value assigned must be an even-numbered byte. If it is not, the 
Assembler will assign an even-numbered address one byte higher than the 
address designated by the START instruction. 

If a START directive is not written as the first statement or the Operand 
field is blank, the Location Coimter is set to zero, and the first statement 
is flagged. A START Assembler instruction at any other point in the pro- 
gram is disregarded from a generation viewpoint but is flagged as an error. 



Chart 7. Example of START Instruction 
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Assembler 
Instructions 



ORG - Set Location 
Counter 



♦ The ORG Assembler instruction allows the programmer to change the 
Location Counter. It can be written at any point in the program and as 
many times as desired. 



The format is as follows: 



NAME 



Not Used 



OPERATION 



ORG 



OPERAND 



The new Location Counter value, S, is the same as in the machine instruc- 
tions , It can be a symbol , an asterisk (see Chart 8) , or a self -defining value . 
When S is a symbol , it must have been previously defined. The Location 
Counter is set to the value of the operand. Any value less than the original 
value of the Location Counter (from the START instruction) is considered an 
error. It is used but it is flagged in the listing. A blank or invalid operand 
is disregarded and flagged in the listing. The program continues to com- 
pile using the previous Location Counter setting if the operand field is in- 
valid. The Name field is not used by the Assembler. 



Chart 8. Example of ORG Instruction 
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END - End of Program 



DEFINITION 
INSTRUCTIONS 

DS - Define Storage 



Assembler 
Instructions 



♦ The END assembly directive is used to indicate that all the statements 
have been processed. It therefore must be the last statement in the user's 
program. The END instruction is also used to indicate to the Loader the 
starting location after the program has been loaded. The format of an 
END instruction is as follows: 

OPEEATION OPERAND 



NAME 



END 



Not Used 

The program starting location , S, is the same as in the machine instruc- 
tions. It can be a sjmibol, an asterisk, a self-defining value, or a blank. 

An invalid operand is treated as a blank operand; both conditions result 
in the generation of a blank address field on the load End card. The listing 
contains a flag if the operand is invalid. 

The Assembler generates a special output card also known as an END 
card for use by the Loader. 



♦ The Define Storage Assembler instruction is used to identify and re- 
serve storage locations. It is the normal means of giving a name to work 
and input/output areas. The format is as follows: 

NAME OPERATION OPERAND 



Symbol 



DS 



A decimal count of 
the number of bytes 
to be reserved followed 
by the Symbol C. 
The length of a DS operand field is only limited by the difference between 
the core size and the present value of the Assembler' s Location Counter. 
A DS statement does not clear the storage it reserves. The Assembler 
does not generate any output cards for these areas. Therefore, the user 
should not expect the areatobe cleared to zeros or blanks. The Assembler 
terminates the object program text card it is currently generating and 
starts a new one for the first statement following the Define Storage state- 
ment. The programmer reduces the size of the output deck by defining his 
DS statement with as few broken sequences as possible. 



Chart 9. Example of DS instruction 
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Assembler 
Instructions 



DC - Define Constant 



♦ This Instruction is used for generating data constants within a program. 
The constants specified may consist of any valid EBCDIC character, hexa- 
decimal digit, or memory address. The DC instruction's statement for- 
mat is as follows: 



NAME 



OPERATION 
DC 



OPERAND 



Symbol DC A single descriptor 

or specifying the constant 

Blank in one of the formats 

defined below. 
There are three types of descriptors for constants. Each descriptor 
specifies both the type of constant, and the constant itself. The formats 
of the constant descriptors are as follows: 



C'z' 
X'z' 
A(z) 



Table 3 defines the format of the three types of constants. 

Table 3. Constant Formats 



Description 


Constant 
Type 


Machine Format 


Implied Length 
in Bytes 


c 


Character 


Eight -bit EBCDIC 


Number of characters 
within 'z' not including 
quotes. 


X 


Hexadecimal 


Fixed-Point 
Binary 


Half the number of 
characters within 'z' 
not including quotes . 


A 


A symbol, 
asterisk or 
self-defining 
value 


Fixed-Point 
Binary 


2 



Z represents the constant, itself, and appears within quotes or parenthesis. 

As shown in Table 3, the length of a constant is implied by the type of 
descriptor used. The maximum length of any C or X type constant is 16 
bytes. The A type constant is always assigned two bytes. If constants of 
greater length are desired, they may be specified by the use of successive 
DC statements. 
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DC - Define Constant 
(Cont'd) 



Character 
Constants - C 



Assembler 
Instructions 



Constants and self-defining values use the same format C'z' andX'z' 
(character and hexadecimal values). When these values are used as oper- 
ands associated with a DC operation code, their maximum number, as 
stated above, may be 16 EBCDIC characters or 32 hexadecimal numbers. 
When they are self -defined values used to define relative addresses, masks, 
operand lengths, etc. , their maximum is four decimal characters or four 
hexadecimal characters. 

♦ A character constant may consist of a maximum of 16 valid characters. 
Valid characters consist of punch combinations which translate into an 
eight-bit EBCDIC code character. The 70/15 Processor Reference Manual 
contains a list of the 256 punch combinations along with their internal 
eight -bit codes and their associated printer symbols. 

Each character of the constant is converted into a single eight -bit byte. 
In the example below, (Chart 10, Statement 1) the constant name HER has 
a length of six bytes. 

Quotation marks are the legal characters in the C-Type constant. A single 
quotation mark is specified by two successive single quotation marks. (See 
Chart 1 , Statement 2 . This constant will be assigned five bytes of memory. ) 



Chart 10. Examples of Character Constant - C 
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Assembler 
Instructions 



Hexadecimal 
Constants - X 



Expression 
Constants - A 



♦ Hexadecimal constants may consist of, and only of, the 16 hexadecimal 
digits: 

0123456789ABCDEF 

The number of digits specified in the constant should be an even number, 
up to andincludingamaximumof 32 hexadecimal digits. Each hexadecimal 
digit requires four binary bits to represent it within memory. For this 
reason, hexadecimal digits are packed two per eight -bit byte in internal 
storage. An example of a hexadecimal constant definition is shown in 
Chart 11. 

If the hexadecimal description specifies an odd number of digits, a zero 
digit is appended to the leftmost end of the constant, andaflag is placed on 
the statement in the listing. 

If the hexadecimal descriptor specifies more than 32 digits, the left- 
most 32 digits are retained and the remaining rightmost characters are 
ignored. This condition causes the statement to be flagged in the listing. 

♦ An expression constant is normally used to define an address. The pro- 
grammer can also use it when it is desired to define a binary constant in a 
decimal format. Two bytes are always generated regardless of the value 
specified. The constant is right- justified, and the leftmost byte is located 
in the next available even position. A zero byte is inserted if a byte must 
be skipped. The constant is defined within parenthesis. Since an expres- 
sion constant is frequently used to represent an address, it is often called 
an address constant. The format is as follows: 



NAME 
ADDR 



OPERATION 
DC 



OPERAND 
A(S) 



S can be a symbol, an asterisk, or a self -defining value (see Chart 12). 
Chart 11. Example of Hexadecimal Constant - X 
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Expression 

Constants - A 

(Cont'd) 



Assembler 
Instructions 



The expression constant allows a self-defining value to have one addi- 
tional feature. A minus sign (-) can precede the value. The Assembler 
generates the two's complement of the value within the 16 bits. Any self- 
defining value that exceeds 16 bits is truncated at the high-order end and 
causes a flag indication on the listing (see Chart 13). 



Chart 12. Example of Expression Constant - A 
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Chart 13. Example of Expression Constant - A 
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PROGRAM LINKING 
INSTRUCTIONS 



ENTRY - Identify 
Entry Point 



Assembler 

Instructions 



4 The ENTRY and EXTRN Assembler verbs provide the facility to load 
and execute, as a unit, programs which are independently assembled. The 
linkage between the program is provided by defining a sjTnbol in one pro- 
gram and referring to the symbol as an operand in the second program. 
The location associated with the symbol in the defining program is called 
an entry point. The references to the entry point in the other assembled 
programs are called external references. Entry points are specified by 
ENTRY or START instructions. External references are defined by 
EXTRN instructions. 

* An entry point is defined by an ENTRY instruction. Entry points cannot 
be specified by relative addressing, therefore, each entry point must be 
defined by a separate ENTRY verb. The one exception is the START in- 
struction which also defines an entry point. The format is as follows: 



NAME 
Not Used 



OPERATION 
ENTRY 



OPERAND 
Symbol 



The symbol in the Operand field must be defined in a name field some- 
where within this assembly program deck. The symbol can be referred to 
by other operands within this program. All ENTRY statements must fol- 
low the START Instruction. An invalid ENTRY statement Is flagged in the 
listing. An invalid statement could be caused by an undefined symbol, or 
invalid operand, or an incorrectly placed ENTRY statement. (See Chart 14. ) 
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Assembler 
Instructions 



EXTRN - Identify 
External Symbol 



Order of Statements 



♦ A reference to an external symbol is defined by an EXTRN instruction. 
A separate EXTRN statement must be written for every external location 
referred to by a program. The format of an EXTRN statement is as 
follows: 



NAME 
Not Used 



OPERATION 
EXTRN 



OPERAND 

Symbol 



All EXTRN statements must follow ENTRY statements. If no ENTRY 
statements appear, the EXTRNs must follow the START instruction. The 
Name field is disregarded. An invalid EXTRN instruction is flagged in 
the assembly listing. An invalid EXTRN could be caused by an invalid 
operand or the improper placement of the EXTRN statement. 

♦ The order of statements for an assembly source program that will be 
linked to other programs at object program running time must be: 

START 

ENTRY 1 

ENTRY 2 

o 

ENTRY n 

EXTRN 1 
EXTRN 2 
EXTRN o 

o 

o 
EXTRN n 

OPERATION STATEMENTS (Includmg DS, DC, ORG Instructions). 

o 
o 
o 
o 

END 
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Assembler 
Instructions 



EXTENDED 

/WNE/WONIC 

INSTRUCTION 

B - Unconditional 
Branch 



4 The Assembler recognizes a B instruction as an unconditional transfer 
of control to the location specified by the Operand field. Its purpose is to 
simplify the writing of Unconditional Branch instructions. The format of 
an Unconditional Branch instruction is as follows: 



NAME 
Symbol 



OPERATION 



B 



OPERAND 

S 



where: S can be a symbol, asterisk, or a self -defining value. The above 
statement could also be expressed as shown in Chart 15. 



Chart 15. Example of Unconditional Branch Instruction 
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INPUT/OUTPUT 

CONTROL SYSTEM 

(IOCS) 

INTRODUCTION 



IOCS Output 



♦ The RCA 70/15 Input/Output Control System (IOCS) is a set of related 
routines that aids the programmer in programming input/output operations 
for the input/output devices listed in Table 4. By including a set of coded 
parameter requests (in 70/15 Assembly language) in his program, the 
programmer can reduce and simplify the amount of coding necessary for 
input/ output operations. 

The programmer supplies only the parameters in his program. The 
IOCS, which at execution time is a subroutine of the user program, uses 
the parameters to perform the desired input/output operations. Then 
IOCS returns control to the user program. 

IOCS performs error detection, but does not, however, provide the 
programmer with device interchangeability. Devices must be selected by 
the programmer in his program. In order that a program may operate 
with a variety of input/output devices , the programmer must make pro- 
visions for modifying or bypassing control functions, recognizing flag 
records or processor functions, and interpreting abnormal and alarm 
returns from the IOCS. 

Input/ output operations can be executed in a Simultaneous or a Non- 
simultaneous mode. Operating in the Simultaneous mode means that pro- 
cessing can occur at the same time that one or more input/output operations 
are occurring. IOCS does this by using the Read Auxiliary instruction 
and buffered devices. The programmer specifies to the IOCS whether or 
not simultaneous or nonsimultaneous processing is to take place. (See 
device parameter area page 32.) 

♦ Output of the IOCS is the initiation or completion of the I/O function re- 
quested. There are three results of an I/O request which are as follows: 

1. Control can return to the user program's normal return address 
under the following conditions: 

(a) If nonsimultaneous processing is specified, control is re- 
turned upon completion of the input/ output operation. 

(b) If simultaneous processing is specified, control is returned 
upon initiation of the input/output operation. The operation 
is not initiated if an error is detected from the previous 
input/output operation. 

2. Control is given to the user's alarm or abnormal return address 
when an alarm or abnormal condition is detected. 
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IOCS 



IOCS Output (Cont'd) 



IOCS Versions 



EQUIPMENT 

CONTROL 

CAPABILITIES 



3. An error halt occurs in the IOCS if an inoperable condition code is 
detected upon designating the I/O device. When the error occurs, 
8F is displayed in the M register on the Console. The trunk and 
unit of the device designated when the error occurred is stored in 
standard location $P+5. 

♦ Two versions of IOCS are provided: one for systems that have magnetic 
tape units, the other for systems that do not. These versions are called 
the magnetic tape version, which requires approximately 950 bytes, and 
the nonmagnetic tape version, which requires approximately 450 bytes. 
Both versions are supplied as a deck of source language cards. 

♦ The IOCS is capable of controlling the operation of the peripheral de- 
vices given in Table 4. 

Table 4. Devices Controlled by IOCS 



Device 


Model 


Magnetic Tape Unit 


70/432-1,-2 
70/442-1,-2 


Magnetic Tape Station (7- or 9- channel) 


70/445-1,-2 


Card Reader 


70/237-10,-20,-30 


Videoscan Document Reader 
(Demand feed only.) 


70/251-10,-21,-22,-30 


Paper Tape Reader/Punch 


70/221-10,-11,-20,-21 


Input/Output Typewriter 


70/216 


Card Punch 


70/234-10,-11 
70/236-10,-11 


Bill Feed Printer 
(continuous forms only) 


70/248-10,-11 


Printer 


70/242-10,-20 
70/243-10,-20 



Devices not controlled by IOCS are: 

1. Videoscan Document Reader, when used in any way other than 
Demand Feed. 

2. Bill Feed Printer, when used for card reading and card printing. 

3. Reader-Punch. This is the Model 70/236 Card Punch with the 
Reader-Pxmch option. 



28 



IOCS 



EQUIPMENT 

CONTROL 

CAPABILITIES 

(Cont'd) 



COMBINING IOCS 

WITH THE USER 

PROGRAM 



4. Data Exchange Control, Model 70/627. 

5. Communication Control, Model 70/652. 



Notes: 
1. 



2. 



The Reader-Punch can have its operations controlled by IOCS, be- 
cause it is controlled by ordinary Read, Write, and Write Control 
instructions. However, the timing of this device may cause it to 
be controlled improperly by the IOCS. 

The Bill Feed Printer requires special purpose routines for its 
input/output. 

The Data Exchange Control and the Communication Control both use 
the interrupt feature , and the IOCS does not provide for interrupts . 
(The Input/ Output Typewriter, which uses the interrupt feature , 
can be controlled by IOCS. However, the programmer must pro- 
vice his own code for all interrupt analysis and processing. ) 



4. For the IOCS to control the Videoscan Document Reader, the fol- 
lowing conditions must prevail: 

(a) Only demand feed operations can be attempted. 

(b) The WCM (Write Control Mandatory) key on the document 
reader must be depressed for documents to be selected into 
the same stacker. This causes a manual override of the 
hardware stacker selection. All documents are routed to 
the reject stacker. 

♦ To use the 70/15 Input/Output Control System, the programmer must 
include certain coding in his program. This coding consists of two classes: 
(1) the instructions needed to define the device parameter area, and (2) the 
IOCS calling sequences. 

A Device Parameter area is aportionof memory that must be set aside 
for storing information that concerns an input/output device. One para- 
meter area must be reserved for each device used by the program. The 
area is reserved by including a set of Define Constant instructions, in a 
specified order in the user program, which supplies information needed 
by the IOCS. 

An IOCS calling sequence is a set of instructions that serves the two- 
fold purpose of supplying information to the IOCS and establishing a re- 
entry address that enables the IOCS to return to the user program. 

The IOCS is a closed subroutine with seven ENTRY points. These 
points are IN, OUT, CHK, CTRL, RWD, RWDA, and TMRK. Each entry 
is made from a programmer-specified calling sequence. Based on the 
entry point, the calling sequence, and the programmer-supplied device 
parameters, the IOCS executes the function desired by the programmer 
and returns control to a return address specified by the programmer. 
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!OCS 



COMBINING IOCS 

WITH THE USER 

PROGRAM (Cont'd) 



Linking Source IOCS 

and Source User 

Program at 

Assembly Time 



Linking IOCS and 

User Program 

In Binding Run 



There are three return addresses associated with each calling sequence. 
These are the normal return address specified in the calling sequence, and 
the alarm address, and the abnormal return address specified in the De- 
vice Parameter Area. 

The IOCS is incorporated into a program by any of the three following 
methods: 

1. Assembling the IOCS with the user program. 

2. Linking the user program with the IOCS by means of a binding run. 

3. Loading the IOCS with a user program that has designated the en- 
trances to the IOCS within the user's program as EXTRN's. 

♦ To include the source IOCS routine in the user source program at as- 
sembly time, the IOCS in source (assembly langu^e) form can be placed 
with the user's source program as one program deck (or one source pro- 
gram on magnetic tape or paper tape) and assembled. It must be remem- 
bered that this is now one source program and must contain only one START 
card and one END card. Also, all ENTRY and EXTRN cards that refer to 
points in the IOCS must be removed before assembly. This composite deck 
is the input to the Assembler. The output is an executable, object program 
including IOCS. The output can be on cards or 80-character card images 
on magnetic tape or paper tape. 

♦ To link the object IOCS and object user program in a binding rim the 
IOCS source deck is supplied with the following ENTRY statements: 



NAME 



OPERATION 


OPERAND 


ENTRY 


IN 


ENTRY 


OUT 


ENTRY 


RWD 


ENTRY 


RWDA 


ENTRY 


CTRL 


ENTRY 


TMRK 


ENTRY 


CHK 



(1) 



where IN, OUT, etc. , are tags in the NAME column of the IOCS source 
program entry points . 



(1) All references to RWD, RWDA, and TMRK apply only to the mag- 
netic tape version of the IOCS. 
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IOCS 



Linking IOCS and 

User Program In 

Binding Run (Cont'd) 



Linking IOCS and 

User Program at 

Load Time 



The user program must contain the following EXTRN statements: 
NAME OPEEATION OPERAND 



EXTRN 


IN 


EXTRN 


OUT 


EXTRN 


RWD 


EXTRN 


RWDA 


EXTRN 


CTRL 


EXTRN 


TMRK 


EXTRN 


CHK 



The IOCS (with the ENTRY'S) mustbe assembled, and the user program 
(with the EXTRN' s) must be assembled. These two object programs, with 
appropriate parameter cards (made up by the programmer) , are input to 
the Binder routine supplied by RCA. Output is one object program that 
combines IOCS and the user object program. 

♦ To link the object IOCS and object user program at load time, the IOCS 
source deck is supplied with the following ENTRY statements: 



NAME 



OPERATOR 


OPERAND 


ENTRY 


IN 


ENTRY 


OUT 


ENTRY 


RWD 


ENTRY 


RWDA 


ENTRY 


CTRL 


ENTRY 


TMRK 


ENTRY 


CHK 



(1) 



where IN, OUT, etc. , are tags in the NAME column somewhere in the 
IOCS source program. 



(1) All references to RWD, RWDA, and TMRK apply only to the mag- 
netic tape version of the IOCS. 
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Linking IOCS and 

User Program at 

Load Time (Cont'd) 



WRITING CALLING 

SEQUENCES AND 

DEVICE PARAMETER 

AREA 

Device Parameter Area 



Simultaneity 
Indicator 



The user program must contain the following EXTRN statements: 
NAME OPERATOR OPERAND 



EXTRN 


IN 


EXTRN 


OUT 


EXTRN 


RWD 


EXTRN 


RWDA 


EXTRN 


CTRL 


EXTRN 


TMRK 


EXTRN 


CHK 



The IOCS (withthe ENTRY'S) must be assembled, and the user program 
(with the EXTRN' s) must be assembled. These two object programs , with 
appropriate parameter cards (made up by the user) , are input to the Relo- 
catable Loader (a routine supplied by RCA) . Output is one object program 
in memory that is ready for execution. There is no physical output, i.e. , 
punched cards , miagnetic tape , etc . 



♦ The Device Parameter area required by the Input/Output System con- 
tains information pertinent to the device. A Device Parameter area must 
be defined for each device through the use of seven Assembler statements. 
(See Chart 16.) If simultaneous processing is specified, only one Device 
Parameter area per device can be defined. If nonsimultaneous proces- 
sing is specified, more than one Device Parameter area per device can 
be defined. 



♦ The entry DC A(S) , 
Parameter area where 



(second line of coding. Chart 16.), in the Device 



S = or 00 means nonsimultaneous and 

S = 1 or 01 means simultaneous, 

causes 2 bytes to be reserved. Only one byte (the right-most) is used for 
the simultaneity indicator. The left-most b5i;e is used by IOCS as a device 
servicing indicator (additional to the Trunk. Status table). This device 
pending indicator may have one of the following two values: 

01 = post status and/or error checking to be accomplished. 
16 

00 = device has been serviced and nothing is pending. 
16 



(1) All references to RWD, RWDA, and TMRK apply only to the mag- 
netic tape version of the IOCS. 
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Simultaneity 
Indicator (Cont'd) 



IOCS Calling 
Sequences 



IOCS, 



Normally the device pending indicator is set by the IOCS. This is done 
so that a check (CHK) , issued before the first input/output operation 
to a device, is effectively treated as a no-op. If the programmer desires 
to execute a CHK function on a device before any input/ output operation on 
that device has been performed, he can set the device pending indicator on 
by defining S = llorS = 10. Then, an initial CHK function is executed, 
rather than ignored. 

♦ To execute an I/O function , the IOCS is entered by one of the following 
fxmction names from a calling sequence coded by the programmer: 

IN - The IN function transfers data from input devices such as mag- 

netic tape, card reader, etc. , into memory. 
OUT - The OUT function transfers data from memory to output devices. 

CHK - The CHK function is used to sense and to store status informa- 
tion pertaining to a particular device. 

CTRL - CTRL is used to perform such control fimctions as selecting 
pimch stackers, printer carriage control fimctions, magnetic 
tape movement, etc. 

RWD - The RWD function is used only to rewind magnetic tapes to BT 
marker. 

RWDA - The RWDA function is used only to rewind and disconnect mag- 
netic tape. 

TMRK - The TMRK function is used to write a tape mark for either 7- 
channel or 9-channel magnetic tape. 

To execute an IN, an OUT, RWD, RWDA, TMRK, or a CHK function, 
the user program must move the appropriate address of the Device Para- 
meter area and the normal return address to the standard area $P. It must 
then execute an Unconditional Branch to the appropriate entry point in the 
I/O Control System. 

To execute a CTRL fimction, the user program must move the address 
of the Device Parameter area and normal return address to $P as above. 
However, the program must also include the hexadecimal representation 
for the desired control function in the calling sequence, and then execute 
an Unconditional Branch to the entry point. The calling sequences are a 
standard means of performing these operations. 



Chart 16. Device Parameter Area 
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IOCS 



Device Parameter 
Area (See Chart 16) 



♦ Statement 1 This statement contains the name that is to be used in the 
calling sequences that refer to this device. The constant, 
defined within the parentheses , specifies the logical device 
number. The allowable values are 00-09. An actual device 
is assigned to the logical device by the I/O Define card at 
load time. 

Note: The allowable values of 00-09 are imposed by the 
Loader. Ifthe entry is insertedby the user by some 
means other than by an I/O Define card, the allow- 
able values are 00-FF. 

Statement 2 This statement contains the constant, defined within the 
parentheses , that specifies whether simultaneous or non- 
simultaneous processing is desired for this device. Zero (0) 
indicates nonsimultaneous processing; one (1) indicates 
simultaneous processing. 

Note: The first byte of this two-byte constant is used as a 
service-pending indicator by the IOCS. The pro- 
grammer is not to refer to this byte because its con- 
tents are variable. 

Statement 3 This statement contains the value , defined within the paren- 
theses , which must be the symbolic name assigned to the 
starting address of the I/O area. This may be the LHE 
(left-hand end) for forward operations or the RHE (right- 
hand end) for reverse operations. The user program can 
modify this value during program execution if desired. 

Statement 4 This statement contains the value, defined within the paren- 
theses , which must be the symbolic name assigned to the 
ending address of the I/O area. This may be the RHE for 
forward operations or the LHE for reverse operations . The 
user program can modify this value during program exe- 
cution if desired. 

Statement 5 This statement contains the value , defined within the paren- 
theses, which must be the name assigned to the first in- 
struction in the user program' s abnormal return subroutine . 
Control is transferred to this address under certain con- 
ditions, called abnormal conditions. 

Statement 6 This statement contains the value , defined within the paren- 
theses , which must be the symbolic name assigned to the 
first instruction of the user program's alarm return sub- 
routine. Control is transferred to this address under cer- 
tain conditions, called alarm conditions. 

Note: If the programmer desires to change the alarm or 
abnormal addresses in statements 5 and 6 , he should 
ensure that no instruction is pending before making 
the change. Wlien changing the addresses in state- 
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IOCS 



Device Parameter 
Area (Cont'd) 



The IN Calling 
Sequence 



Note: ments 5 and 6 , it must be remembered that it is 

(Cont'd) possible for the IOCS to return to either of these 
returns at two different times . 



Statement 7 



This statement allocates a 12-byte working storage area in 
which status information, the final A-address, and other 
data are stored during program execution. If the nontape 
version of the I/O Control System is used, only four bytes 
of working storage must be provided. If the magnetic tape 
version is used, statement 7 of all Device Parameter areas, 
regardless of device type , must allow for a 12-byte area. 



The device parameters will subsequently appear in memory as follows: 



Logical 
Device # 



Device 

Pending 

Indicator 



Simultan- 
eity 
Indicator 



Starting 
Address 



Ending 
Address 



Abnormal 

Return 

Address 



Alarm 
Return 
Address 



+0 +1 



-3 +4 +5 



-6 +7 



+ i 



+9 +10 +1] 



A -Final 
Address 


Standard 
Device 


I/O 
Sense 


Working Storage for I/O Control | 


Cyclic 


OP 


Trimk 


Dl 




Byte 


Byte 


Parity 
Character 
(9 Level Tape) 


Code 


and 
Device 


Address 



-12 +13 



-14 +15 



+ 16 



+ 17 



+18 +19 



-20 



(Cont. ) 



D2 
Address 



Write 

Control 

Character 



+ 21 +22 



+ 23 



The first 12 bytes are the parameters defined by the programmer. The 
second 12 bytes are reservedbythe programmer and filled in by the IOCS. 
If the nontape version is being used, only four bytes are reserved by the 
program and used by the IOCS . 

After termination of every operation, or when control is returned to either 
the abnormal or alarm addresses, the A-final address, the standard de- 
vice byte, and the I/O sense byte are posted in the Device Parameter area 
for that device. In magnetic tape operations, the entire I/O instruction is 
stored in bytes +17 ~ +22 for error recovery (rollback) procedures. 

♦ The IN calling sequence, required to execute an input function, is shown 
in Chart 17. 

Statement 1 This statement contains a Move instruction that transfers 
the return address (specified by Statement 3) and the ad- 
dress of the Device Parameter area (specified by State- 
ment 4) to the standard area $P. 
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IOCS 



The IN Calling 

Sequence 

(Cont'd) 



The OUT Calling 
Sequence 



Statement 2 This statement contains an Unconditional Branch to the IN 
entry point of the IOCS. 

Statement 3 This statement contains the address to which control is re- 
turned under normal circumstances. 

Statement 4 This statement contains the name assigned to the Device 
Parameter area describing the device to which this com- 
mand is issued. 



♦ The OUT calling sequence, required to execute an Output function, is 
shown in Chart 18. 

Statement 1 This statement contains a Move instruction that transfers 
the return address (specified by Statement 3) and the ad- 
dress of the Device Parameter area (specified by Statement 
4) to the standard area $P. 

Statement 2 This statement contains an Unconditional Branch to the OUT 
entry point of the IOCS. 

Statement 3 This statement contains the address to which control Is re- 
turned under normal circumstances . 

Statement 4 This statement contains the name assigned to the Device 
Parameter area describing the device to which this com- 
mand is issued. 



Chart 17. IN Calling Sequence 
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Chart 18. OUT Calling Sequence 
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The RWD Calling 
Sequence 



RWD A Calling 
Sequence 



IOCS 



^ The RWD calling sequence, required to execute a magnetic tape rewind 
to BT markers is shown in Chart 19. 

Statement 1 This statement contains a Move instruction that moves the 
normal return address (specified by Statement 3) , and the 
address of the Device Parameter area (specified by State- 
ment 4) , to the standard location in lower memory called $P . 

Statement 2 This statement contains an Unconditional Branch to the RWD 
entry point of the IOCS. 

Statement 3 This statement contains the address to which control is re- 
turned after the RWD operation is completed. 

Statement 4 This statement contains the name assigned to the Device 
Parameter area that defines the device to which this com- 
mand is issued. 

« The RWDA calling sequence, required to execute a magnetic tape rewind 
and disconnect, is shown in Chart 20. 



Statement 1 



Statement 2 



This statement contains a Move instruction which moves 
the normal return address (specified by Statement 3) and 
the address of the Device Parameter area (specified by 
Statement 4) to a standard location in lower memory called 
$P. 

This statement contains an Unconditional Branch to the 
RWDA entry point of the IOCS. 



Chart 19. RWD Calling Sequence 
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Chart 20. RWDA Calling Sequence 
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IOCS 



RWDA Calling 

Sequence 

(Cont'd) 



The TURK Culling 
Sequence 



The CTRL Calling 
Sequence 



Statement 3 This statement contains the address to which control is re- 
turned after the RWDA operation is completed. 

Statement 4 This statement contains the name assigned to the Device 
Parameter area that defines the device to which this com- 
mand is issued. 

♦ The TMRK calling sequence, required to write a tape mark (either 7- 
or 9-channel) on magnetic tape, is shown in Chart 21. 

Statement 1 This statement contains a Move instruction that moves the 
normal return address (specified by Statement 3) and the 
address of the Device Parameter area (specified by State- 
ment 4) to a standard location in lower memory called $P. 

Statement 2 This statement contains an Unconditional Branch to the 
TMRK entry point of the IOCS, 

Statement 3 This statement contains the address to which control is re- 
turned after the TMRK operation is completed. 

Statement 4 This statement contains the name assigned to the Device 
Parameter area that defines the device to which this com- 
mand is issued. 

♦ The CTRL calling sequence , required to execute a write control fxmction , 
is shown in Chart 22. 



Statement 1 



Chart 21. TMRK Calling Sequence 



This statement contains a Move instruction that moves the 
normal return address (specified by Statement 3) , the ad- 
dress of the Device Parameter area (specified by Statement 
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Chart 22. CTRL Calling Sequence 
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IOCS 



The CTRL Calling 
Sequence (Cont'd) 



4) , and the control information (specified by Statement 5) 
to a standard location in lower memory called $P. 

Statement 2 This statement contains an Unconditional Branch to the 
CTRL entry point of the IOCS. 

Statement 3 This statement contains the address to which control is re- 
turned after the CTRL operation has been completed. 

Statement 4 This statement contains the name assigned to the Device 
Parameter area that defines the device to which this com- 
mand is to be issued. 

Statement 5 This statement contains the control information that is sent 
to the device. This data is written in the form of two hexa- 
decimal characters that generate the proper binary con- 
figuration required by the device . The formats of the various 
control bytes, by device, are defined on page . The 
control byte is sent to the device by means of a Write Con- 
trol instruction by the IOCS. 

Table 5 contains the two control characters that are issued to various 
devices . It should be noted that any control to the printer that specifies 
paper advance following the next write is voided by the next OUT issued 
to the printer. 

Table 5. Control Characters 



Model, 
Device 


Hexadecimal 

Control 

Characters 


Meaning 


70/216 

I/O Typewriter 




Write control is not possible on 
the 70/216 I/O Typewriter 


70/221 
Paper Tape 
Reader/Pimch 




Write control is not possible on 
70/221 Paper Tape Reader/Punch 


70/234 
Card Punch 


01 
02 


Set translate mode. 

Set column binary mode . 


70/236 
Card Punch 


01 
02 


Set translate mode. 

Set column binary mode. 


Additional Control 
Bytes for 70/236 
Card Punch (Reader/ 
Punch) ^ 


04 
08 


Override hardware stacker selec- 
tion made at wait station No . 2 
(after card has been read) . 
Override hardware stacker se- 
lection at postpimch station (after 
card has been punched) . 



(2) The Videoscan Document Reader , the Bill Feed Printer , and the Reader/ 
Pimch require special consideration. See the section on equipment 
control capabilities. 
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IOCS 



The CTRL Calling 
Sequence (Cont'd) 



Table 5. Control Characters (Cont'd) 



Model, 
Device 



70/236 (cont'd) 



Hexadecimal 

Control 

Characters 



70/237 
Card Reader 



70/432, 70/442, 
70/445 Magnetic 
Tapes 



70/242, 70/243 
Printer or 70/249 
Bill Feed Printer 
(used to print con- 
tinuous forms only) , 



70/251 
Document 
Reader (Demand 



(2) 



Feed only) 



10 



20 

01 
02 
04 
08 

01 

02 
08 
10 
20 
80 
4X 

OX 

cx 

8X 

01 
02 
04 
08 
10 



Meaning 



Override stacker selection at post- 
punch read (after hole count check 
has been made) . ( There is a timing 
consideration in the use of this con- 
trol byte . The instruction must be 
executed within 3. 5 milliseconds 
after punching has been completed. ) 

Move the transport one station. 
(This does not read a card. ) 

Select accept stacker. 
Select reject stacker. 
Set translate mode 
Set column binary mode. 

Unwind to tape mark. 

Rewind to tape mark. 

Unwind one gap. 

Rewind one gap. 

Rewind to load point and disconnect. 

Rewind to BT marker. 

Paper advance immediately per 
line count specified by X. 
Paper advance following next 
write, per line count specified by X. 
Paper advance Immediately to 
channel selected by X. 
Paper advance following next write 
to channel specified by X. 

Select accept stacker. 
Select reject stacker. 
Set translate mode. 
Set column binary mode. 
Demand feed. 



(2) The Videoscan Document Reader , the Bill Feed Printer , and the Reader/ 
Pimch require special consideration. See the section on equipment 
control capabilities. 
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IOCS 



The CHK Calling 
Sequence 



♦ The CHK calling sequence, required to execute a check function, is 
shown in Chart 23. 

Statement 1 This statement contains a Move instruction which transfers 
the return address (specified by Statement 3) and the ad- 
dress of the Device Parameter area (specified by Statement 
4) to the standard area $P. 

Statement 2 This statement contains an Unconditional Branch to the CHK 
entry point of the IOCS. 

Statement 3 This statement contains the address to which control is re- 
turned under normal circumstances. 

Statement 4 This statement contains the name assigned to the Device 
Parameter area describing the device to which this com- 
mand is to be issued. 



Chart 23. CHK Calling Sequence 
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IOCS 



FUNCTIONS 
OF THE IOCS 



Exceptional Conditions 



♦ The following functions are performed by the IOCS each time the routine 
is entered at any of its seven entry points. 

1. The Logical Device number, specified in the Device Parameter 
area, is translated into the actual device number assigned by the 
I/O Define Card at load time. 



2. 



When simultaneous processing is specified, a check (CHK) is per- 
formed before each I/O operation (except the first) to test the ter- 
mination of the previous operation. When nonsimultaneous proces- 
sing is specified, a check is performed after the I/O operation. 

The A-final address, the standard device byte, and the I/O sense 
byte are posted in the Device Parameter area as part of the activity 
of the check (CHK) function. 

The device pending indicator in the Device Parameter area is then 
checked to see if the last reference to this device was serviced. 
If necessary, the standard device byte and the I/O sense byte are 
checked. If other than a normal condition is detected, steps are 
taken to perform Rollback or return to the alarm or abnormal 
return addresses. 

If neither the device pending indicator nor an exceptional condition 
is detected, the IOCS checks to see if this was a CHK ENTRY. If 
it was a CHK, control is returned to the user's normal address. 
If it was not a CHK ENTRY, control is turned over to the I/O issue 
portion of the IOCS. 

The I/O issue portion of the IOCS acts depending upon the ENTRY 
point, the simultaneity indicator in the device parameters, the 
device type in the Device Correspondence table , and the relation 
of the starting and ending addresses in the Device Parameter area. 

♦ Exceptional conditions are classified into the following two groups: 

1. Abnormal 

2 . Alarm 

When an exceptional condition arises during the execution of an input/output 
operation, it results in a transfer of control. This transfer of control is 
to the address specifiedby the programmer in the Device Parameter area 
for processing that type of condition rather than to the normal return ad- 
dress as specified in the calling sequence of the I/O request. 

The IOCS usually returns control to the user's normal return address. 
When an abnormal or alarm condition occurs , IOCS returns control to the 
programmer-specified Alarm routine address or to the programmer- 
specified Abnormal routine address. The programmer specifies these re- 
turn addresses in the Device Parameter area. 



6. 
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IOCS 



Exceptional 
Conditions (Cont'd) 



There are five a bnormal conditions 
end-of -forms . 



all concerned with end-of -file or 



Nonsimultaneous 
Mode IN Function 

Card Readers 



Magnetic Tape 



The many alarm conditions are usually concerned with 
equipment malfunctions, invalid characters, and illegal operations. 

Read parity error rollback and read-after-write rollback are automa- 
tically performed by the IOCS for magnetic tapes. 

Table 6 specifies the I/O sense bytes of the various device types, show- 
ing the bit that is set as a result of the described exceptional condition, 
and the return address to which the IOCS will transfer control. 

IOCS determines the type of error and performs error recovery if ap- 
propriate. Should the IOCS return to the alarm address after an I/O 
attempt to read or write a magnetic tape, the tape is positioned before 
the bad record on a read reverse, after the bad record on a read forward, 
or before the next available segment of tape on a write. 



♦ 1. A Read Forward instruction is issued. 

2. Data is transferred from the card reader to memory beginning 
with the Bi address, which is specified in the Device Parameter 
area, and terminating when the lesser of (D2-D1+1) or 80 bytes 
have been transferred. 

3. A CHK is performed, and the appropriate routine (abnormal or 
alarm) in the user program is entered if an error exists. 

4. The A-final address, standard device byte, and I/O sense byte 
are stored in the Device Parameter area. 

5. Control is returned to the normal returnaddress if no errors occur. 



♦ 1. The packing density, etc. , is set if necessary. 

2. If Di < D2> A Read Forward instruction is issued. If Di > D2, a 
Read Reverse instruction is issued. 

3. Data is transferred to memory beginning with the D-^ address , 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) bytes are transferred. 

4. A check (CHK) is performed and the appropriate routine (abnormal 
or alarm) in the user program is entered if an error exists . 

5. The A-final address , the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 
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Table 6. I/O Sense Bytes 










\ Return 
\ Address 
\ ~ 


Alarm 


Alarm 


Alarm 


Alarm 


Alarm 


Alarm 


Abnormal 


Alarm 


Device \ Bit 

\ Positive Set 


2' 


2« 


2= 


2" 


23 


22 


2' 


20 


70/236 Card Punch 
70/234 


Pimch 

Comparison 
Error (PCE) 


Punch 
Memory 
Parity 
Error 


Not 
Used 


Transmission 
Parity Error 


Intervention 
Required 
Stacker full 
Hopper empty 
Chip box full 


Hold 


Not 
Used 


Illegal 
Operation 


70/237 „ . „ J 
70/232 ^^""^ ^^^'''' 


Read Error 


Service 
Request 
Not 
Honored 


Stacker 
Selection 
Too 
Late 


Invalid Punch 
Code 


Not Used 


Hold 


Not 
Used 


Illegal 
Operation 


70/251 Document Reader 


Read Error 


Service 
Request 
Not 
Honored 


Stacker 
Selection 
Too 
Late 


Unreadable 
Data 


Feed Error 


Not 
Used 


Read 
Late 


niegal 
Operation 


70/221 Paper Tape 
Reader 


Parity Error 


Service 
Request 
Not 
Honored 


Not 
Used 


Not Used 


Intervention 
Required 


Hold 


Not 
Used 


Illegal 
Operation 


Punch 


Parity Error 


Not Used 


Not 
Used 


Not Used 


Intervention 
Required 


Hold 


Low 
Tape 


niegal 
Operation 


70/242 „ . ^ 
70/243 ^""*^^ 


Print Error 


Not Used 


Not 
Used 


Channel 
Parity Error 


Invalid Code 


Hold 


Low 
Paper 


Illegal 
Operation 


70/214 Input/Output 
Typewriter 


Write Error 


Time 
Lapse 


Not 
Used 


Transmission 
Parity Error 


Data Error 


Not 
Used 


Not 
Used 


Illegal 
Operation 


70/432 Magnetic Tape Unit 
70/442 Magnetic Tape Unit 
70/445 Magnetic Tape 
Station 


*Read Error or 
Read After 
Write Error 


Service 
Request 
Not 
Honored 


Data block 
Greater 
Than 
Count 


Transmission 
Error 


Magnetic 
Tape Alarm 


— 

BT/ET 


Tape Mark 


Illegal 
Operation 


70/249 Bill Feed 

Printer 


Channel 12 
Sensed 


Channel 9 
Sensed 


Print 
Check 


Transmission 
Parity Error 


Code Error 


Manual 
Service in 
Progress 
(Hold) 


End-of- 

Forms 


Illegal 
Operation 



Co 



*The return to the user program at the alarm address occurs only after rollback procedures in the IOCS have failed. 



IOCS 



Magnetic Tape 
(Cont'd) 



Paper Tape 
Reader 



Input/Output 
Typewriter 



N on simultaneous 
Mode OUT Function 

Card Punches 



6. Control is returnedto the normal return address if no errors occur. 

Note 1: The nontape version of IOCS should not be used for config- 
urations that include magnetic tapes . 

Note 2: If data termination is caused by a (D2-EH-1) byte transfer 
and a gap is not encountered, a data-greater-than-coimt 
condition exists . This error condition effects a return 
to the alarm return address in the user program. 

♦ 1. If Dj^ < D2, a Read Forward instruction is issued. If Dj > B^, 

a Read Reverse instruction is issued. 

2. Data is transferred to memory beginning with the T)-^ address, 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) bytes are read. 

3. A check (CHK) is performed and the appropriate routine (abnormal 
or alarm) in the user program, is entered if an error exists. 

4. The A-final address, the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 

5. Control is returned to the normal return address if no errors occur. 

♦ An I/O Device Request Interrupt occurs in the processor when an oper- 
ator writes a message into memory by means of the Input/Output Type- 
writer. When the processor is interrupted, the cause of this interrupt is 
not immediately evident and must be determined by a user-programmed 
routine. After it is determined that the interrupt is a request to transmit 
from the Input/Output Typewriter, the user program then enters the IOCS 
through the IN entry point in the normal way, that is, by use of an IN 
calling sequence. 

1. A Read Forward instruction is issued to the typewriter. 

2. Data is transferred to memory beginning with the D^ address, 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) bytes are transferred, or the END key is pressed, 
or the ERROR key is pressed, or a 15-second time-out occurs. 

3. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists. 

4. The A-final address, the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 

5. Control is returnedto the normal return address if no errors occur. 



♦ 1. A Write instruction is issued. 
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IOCS 



Card Punches 
(Cont'd) 



Magnetic Tape 



Paper Tape 

Punch 



2. Data is transferred from memory begirniing with the Dj^ address, 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) or 80 bytes are transferred. 

3. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists. 

4. The A-final address , the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 

5. Control is returned to the user's normal return address if no 
errors occur. 

♦ 1. A Write Control instruction is issued to set the packing density, 
if necessary. 

Note: If data termination is caused by a (D2-D1+1) byte transfer 
and a gap is not encountered, a data-greater-than-count 
exists. This error condition effects a return to the alarm 
return address in the user program. 



A Write instruction is issued. 

Data is transferred from memory beginning with the D^ address , 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) bytes are written. 



4. A check (CHK) is performed and the appropriate routine in the 
user program is entered if an error exists. 

5. The A-final address, the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 

6. Control is returned to the normal return address if no errors occur. 



♦ 1. A Write instruction is issued. 

2. Data is transferred from memory beginning at the D-|^ address, 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) bytes are written. 

3. A check (CHK) is performed and the appropriate routine in the 
user program is entered if an error exists. 

4. The A-final address, the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 

5 . Control is returned to the normal return address if no errors occur . 
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IOCS 



Input /Output 
TypewriteT 



♦ 1. A Write instruction is issued. 

2. Data is transferred from memory beginning with the D^ address, 
which is specified in the Device Parameter area, and terminating 
when (D2-D1+1) bytes are written. 

3. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists . 

4. The A-final address, the standard device byte, and the I/O sense 
byte are stored in the Device Parameter area. 

5 . Control is returned to the normal return address if no errors occur . 

Note: Error checking occurs after the execution of the Write in- 
struction. However, error checking does not occur fol- 
lowing the execution of a Write Instruction that effects 
form control. 



Printer ♦ 1. A Write Control instruction is issued to the printer to effect form 
control. The form control is specified by the programmer. The 
first byte of the line that is to be printed is interpreted as the control 
byte. This character is not printed. This control character has 
the following format: 

12 3 
2,2,2,2 = a binary count of the number of lines to advance 

(0-15) or a binary number that selects one of 11 loop channels 

(1-11), depending on the setting of bit 2'. 

2,2= Ignored. 

2 = - paper advance after print. 

2 = 1 - paper advance before print. 

7 3 

2 = - paper advance per count in 2 - 2 . 

7 
2 = 1 - paper advance under control of paper tape loop channel 

selected by bits 2^ - 2^. 

2. A Write instruction is issued. 

3. Data is transferred from memory beginning at the Yii address plus 
one byte and is terminated when (D2-D1+1) bytes are transferred, 
or the printer's buffer is full (132 or 160 bji;es). 

4. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists . 

5. The A-final address, the standard device byte , and the I/O sense 
byte are stored in the Device Parameter area. 
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6. Control is returned to the normal return address if no errors occur. 

7. When specifying forms control and no printing is desired, at least 
part of a blank line should be generated after the forms control 
character. The starting and ending addresses of the message given 
in the Device Parameter area should not specify only a single char- 
acter. This causes the IOCS to print a full line. 

Note: Error checking occurs after the execution of the Write in- 
struction. However, error checking does not occur follow- 
ing the execution of a Write instruction that effects form 
control. 



♦ 1. A Read Auxiliary instruction is issued. 

2. After the instruction is successfully initiated, control is trans- 
ferred to the normal return address in the user program. 

3. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists . This is a check for the 
previous I/O operation. On the first input/ output operation to a 
device , a check is not performed. 

4. Datais transferred into memory beginning at the D]^ address, which 
is specified in the Device Parameter area, and terminating when 
80 bytes are transferred or the end of memory is reached. (Transfer 
of (D2-D1+1) bytes does not terminate the instruction.) 

5. No check (CHK) is made imtil the user program refers to this 
device again. 



♦ 1. The packing density, etc. is set, if necessary. 

2. A Read Auxiliary instruction is issued if D^ < D2. If D^ > D2, a 
Read Reverse instruction is issued. 

3. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists. This is a CHK for the pre- 
vious l/O operation. On the first input/output operation to a device, 
a CHK is not performed. 

4. After the instruction is successfully initiated, control is transfer- 
red to the normal return address in the user program. 

5. Data is transferred into memory beginning at the D-^ address, which 
is specified in the Device Parameter area, and terminating when a 
gap is encoimtered or when the end of memory is reached. 
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OUT Function 



Check Function (CHK) 



6. No check (CHK) is made until the user program refers to this de- 
vice again. 

Note: The nontape version of IOCS should not be used for config- 
urations that include magnetic tape. 



♦ 1. A Read Auxiliary instruction is issued if Dj < D2. If D-j^ > D2, a 
Read Reverse instruction is issued. 

2. After the instruction is successfully initiated, control is transferred 
to the normal return address in the user program. 

3. A check (CHK) is performed and the appropriate routine in the user 
program is entered if an error exists. This is a CHK for the pre- 
vious I/O operation. On the first I/O operation to a device a CHK 
is not performed. 

4. Data is transferred into memory beginning at the D]^ address, which 
is specified in the Device Parameter area, and terminating when a 
gap on tape is encountered or the end of memory is reached. 

5. No check (CHK) is performed imtil the user program refers to this 
device again. 



♦ An IN fimction in the Simultaneous mode should not be issued to the 
Input/Output Typewriter. 



♦ The OUT functions, when performed in the Simultaneous mode, are 
identical to those in the Nonsimultaneous mode with the following ex- 
ception: Control is transferred to the normal return address immediately 
after the Write Auxiliary instruction is issued. The CHK for an I/O oper- 
ation is not given imtil the next calling sequence that refers to this device. 
The primary use of the OUT function in the Simultaneous mode is to use 
the buffered output devices. 

4 Entering the IOCS by means of the CHK entry causes a check to be 
made of the previous termination for the device referred to. The IOCS 
executes Rollback, if necessary, posts status conditions to the Device 
Parameter area, and, if no errors have occurred, transfers control to 
the normal return address. If a condition exists that is not normal, con- 
trol is passed to the appropriate address (either alarm or abnormal) in 
the user program for processing. 

The CHK function executes a Post Status instruction and an I/O Sense 
instruction. Ifthe secondary indicator is set (bit 2^ of the standard device 
byte), or if the device inoperable bit is set (bit 2^ of the standard device 
byte), the IOCS branches to the user's abnormal or alarm address accord- 
ing to the conditions listed by device in Table 6 on page 44. 
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Considerations 



The standard device byte is stored in the reserved memory location 
for that trunk and unit. The sense byte is stored internally in the IOCS 
program. Both are stored in the Device Parameter area. 



♦ There are three device control functions that are not automatically 
performed by the IOCS. These are: 

1. Setting the Binary mode on card equipment. 

2. Selection of output stackers on card equipment. 

3. Control functions for the Videoscan Document Reader. 

The control (CTRL) fimction permits the programmer to perform these 
fimctions. If the programmer esires his program to work with a variety 
of devices (device interchangeability) , he should modify or bjToass these 
CTRL functions accordingly. 

Control operations that are not covered by the RWD, RWDA, or TMRK 
calling sequences must be done by using the CTRL calling sequence. Upon 
completion of the operation, a check (CHK) is performed. 



♦ The function of the RWDA calling sequence is to rewind and disconnect 
magnetic tapes only. When the operation is completed, control is trans- 
ferred to the normal return address. If a RWDA is issued to a device 
other than to a magnetic tape , no I/O instruction is issued and control is 
immediately transferred to the normal return address. 



^ The function of the TMRK calling sequence is to write a tape mark on 
either 7- or 9-channel magnetic tape. When the operation is complete , 
control is transferred to the normal return address. If a TMRK is issued 
to a device other than to a magnetic tape, no I/O instruction is issued and 
control is immediately transferred to the normal return address. 



♦ The function of the RWD is to rewind magnetic tape to the BT marker 
only. When the rewind has been initiated, control is transferred to the 
normal return address. If a RWD is issued to a device other than to a 
magnetic tape, no I/O instruction is issued and control is immediately 
transferred to the normal return address. 



♦ 1. If simultaneous processing is specified, users of the IOCS must 
define only one Device Parameter area for each device. If the user 
wishes to execute an IN or OUT function in an area other than the 
area specified in the Device Parameter area, he must modify the 
starting and ending addresses indicated in the parameters. 

2. If nonsimultaneous processing is specified or a check (CHK) function 
is executed before issuing the next I/O function, more than one 
Device Parameter area can be specified. 
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3. The Read Reverse I/O command is available for use only by the 
magnetic tape version of the IOCS. 

4. If simultaneous processing is specified, users of the IOCS must 
perform a check (CHK) on the final read (end-of-rim) to determine 
the validity of the information. 

5 . The 70/15 IOCS performs physical input/output operations , but does 
not perform logical input/output operations. If a tape file contains 
batched records, it is the programmer's responsibility to process 
the individual records within the block. IOCS treats the block of 
records as a single input -output record. 

Note: The 70/221 Paper Tape Punch does not generate a gap auto- 
matically at the termination of a Write instruction. The 
programmer is responsible for generating gaps if they are 
desired. This is done by including one or more bytes con- 
taining all zeros (0000 0000) atthe end of each block written. 



♦ The logical device code , which appears on the first line of coding of the 
Device Parameter area, must be the same code for a given device as the 
code on the I/O Define card for that device. For example, if the Card 
Reader is called logical device number 6 on the I/O Define cards to be 
introduced with this program to the Loader, then the Card Reader must 
have logical device code 6 on the first line of coding of the Device Para- 
meter area as follows: NAME DC A(6). 

4 At load time, the Device Correspondence table (DCT) is created by the 
Loader using information contained in the I/O Define cards. The DCT is 
the table in which actual devices are related to their device numbers. The 
DCT contains three bytes of information for each device. The Loader sets 
up places for 10 entries and fills them in as it reads I/O Define cards. 
The user may store additional entries provided that they are in the correct 
format. The starting address of the DCT is 152j^q. 

The magnetic tape version of the IOCS can handle as many devices as 
there are entries in the DCT, The nontape IOCS assumes that there is 
only one device per trimk (hence , six devices) . Multiple device trimks 
can be used if the programmer specifies nonsimultaneous processing, or 
does not refer to a second device until the previous device is terminated. 
When the programmer ensures device servicing on multiple device trunks , 
the nontape IOCS can handle as many devices as there are designated in 
the DCT. 

The format of the DCT is as follows: 



Logical Device 


00 




01 




Memory Locations 


152 


153 


154 


155 


156 


157/ 


Contents 


A 


B 


C 


A 


B 


C { 

/ 



09 



180 



B 



181 
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A, B, and C are bytes defined as follows: 



Byte A 


Bjte B 


Byte C 


4 bits 


4 bits 


4 bits 


4 bits 


8 bits 


TK. No. 


DEV. No. 


ALT. TK. No. 


DEV. TYPE 


CONTROL BYTE 



Where: TK. No. is trunk number (range 0-5) 

DEV. No. is logical device number (range 0-9). (This can have 
the range 0-F if the programmer inserts additional entries in the 
DCT). 

ALT. TK. No. is the number of the alternate trunk by which the 
device can be accessed. This is not used by IOCS. 

DEV. TYPE code has the following values and meanings: 

- DXC Data exchange control (not supported by IOCS). 

1 - Magnetic Tape. 

2 - CardReaderorVideoscanDocumentReader (Card Reader 

only). 

3 - Card Punch. 

4 - Paper Tape Reader. 

5 - Paper Tape Punch, 

6 - On-line Printer or Bill Feed Printer (continuous forms 

only) . 

7 - Input/Output Tj^ewriter. 

8 - Card Reader/Pxmch. 

9 - Single channel communications device (not supported by 

IOCS). 

Note: This device group will be expanded later to include the 
Videoscan Document Reader and the Bill Feed Printer. 

CONTROL BYTE , byte C (see Table 7) , is the information needed to 
prime a 7-channel magnetic tape device for the correct packing density 
and level. The hexadecimal codes for the control are defined in the section 
on I/O Define cards . Byte C is set to zeros by the IOCS for all devices 
other than 7-channel magnetic tapes. 
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I/O Define Cards 



Table 7. Legftlmate 


7-Channe1 Control Byte Configuration* 






Hexa- 






Pock/ 




Bits 


decimal 


Density 


Parity 


Unpack 


Translator 


11110000 


FO 


800 


odd 


on 


off 


10110000 


BO 


556 


odd 


on 


off 


01110000 


70 


200 


odd 


on 


off 


11101000 


E8 


800 


odd 


off 


on 


10101000 


A8 


556 


odd 


off 


on 


01101000 


68 


200 


odd 


off 


on 


11100000 


EO 


800 


odd 


off 


off 


10100000 


AO 


556 


odd 


off 


off 


01100000 


60 


200 


odd 


off 


off 


11001000 


C8 


800 


even 


off 


on 


10001000 


88 


556 


even 


off 


on 


01001000 


48 


200 


even 


off 


on 


11000000 


CO 


800 


even 


off 


off 


10000000 


80 


556 


even 


off 


off 


01000000 


40 


200 


even 


off 


off 



* This byte is not checked by the IOCS. It is the responsibility of the 
programmer to ensure that the setting of this bjrte is correct. 

♦ At program load time , a set of load cards must be supplied to the Loader 
program. One type of load card is the I/O Define card, which supplies 
DCT information to the loader. Each I/O Define card causes the Loader 
to set up one three-byte entry in the DCT. The information contained in 
the l/O Defin6 cards is given in the following format: 



Column 


1 


2 


3 


4 5 


6 


7 8 


9 


10 


11 12 


13 - 80 


Content 


V 





L 


X X 


A 


t u 


a 


d 


h h 


Ignored 



Column 



Content 



1 - Must contain V. Identifies this card as a load card. 

2 - Must contain 0. This identifies the load card as an I/O Define 

card. 

3 - Must contain L, for logical device xx. 

4-5 - The designation xx is the logical device number to which the actual 
device tu is assigned. The range of xx is 00 to 09. 

6 - Must contain A, for actual device tu. 

7-8 - The designation tu is actual device number. The range of trtmk 
number , t , is to 6 , and its unit , u , is from to F . 
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Column (Cont'd) 



Content (Cont'd) 



9 - The designation a is the alternate trunk (0-6) from which the device 
may also be accessed. 

10 - The designation d is the device type being defined. Its range and 
meaning are as follows: 

DXC (not supported by IOCS) . 

1 Magnetic Tape 

2 Card Reader 

3 Card Punch 

4 Paper Tape Reader 

5 Paper Tape Punch 

6 Printer 

7 Input/Output Typewriter 

8 Card Reader/Pimch 

9 Single channel communications (not supported by IOCS) . 

11-12- The designation hh is the hexadecimal representation of the con- 
trol b3i;e to be issued to a 7-channel Magnetic Tape Station to set 
its mode of processing. If 00 (or blanks) is specified, a 9-channel 
tape is assumed. 

♦ Note that there are three numeric codes associated with each device. 
These are: xx, logical device number, 

d, device type, and 

tu, trimk and unit of referenced device, sometimes called 
actual device numbers. 

The device type, d, is a code which stands for the description in words of 
the device. For example, 2 means Card Reader. 

In the I/O Define card format, the logical device number, xx, is a pro- 
grammer-supplied code name for the device referred to. In effect, it is 
the name of the device for the programs in which it is used. 

The trunk and unit , tu, is the specific hardware designation of the device. 
In effect, it is a hardware address of the device. For an installation, the 
device type (d) connected to a particular trimk and unit (tu) is the same for 
all programs using that configuration. Only the logical device type (xx) 
may change, or, in other words, the programmer can call a device type 
on a trunk and unit by different names in different programs . 
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Example 1: Same devices , different names . The programmer supplies 

a set of I/O Define cards to specify: 



Logical Device 

00 
01 
02 
03 
04 



Trimk, Unit 

0,0 
0,1 
1,0 
2,0 
3,0 



Device Type 

1 (Magnetic Tape) 

1 (Magnetic Tape) 

2 (Card Reader) 

3 (Card Punch) 
6 (Printer) 



Then the programmer uses 02 to refer to the Card Reader 
in his program , 04 to refer to the Printer , etc . 
If the I/O Define cards specified: 



Logical Device 


Trimk, Unit 


Device Type 


01 


0,0 


1 (Magnetic Tape) 


00 


0,1 


1 (Magnetic Tape) 


09 


1,0 


2 (Card Reader) 


07 


2,0 


3 (Card Punch) 


08 


3,0 


6 (Printer) 



Example 2: 



Then the programmer must use 09 to refer to the Card 
Reader, 08 to refer to the Printer, etc. 

Interchanging devices. If a program specifies the Card 
Pimch as the output device and calls it logical device 05 , 
then an I/O Define card must specify: 



Logical Device 



05 



Trunk, Unit 
2,0 



Device Type 
3 (Card Punch) 



where the trunk and unit are taken to be as before . Then , 
if it is desired to have the output on magnetic tape instead 
of on cards, the program refers only to device number 05. 
All that is required to make this change is to replace the 
above described I/O Define card with an I/O Define card 

m 

specifying the following: 



Logical Device 



05 



Trunk, Unit 
0,1 



Device Type 
1 (Magnetic Tape) 



where one of the Magnetic Tape Units described is now 
used as the output device. 

The IOCS, acting only on the reference in the program to 
logical device number 05 , goes to the Device Correspond- 
ence table (DCT) for the fifth entry, and using the inform- 
ation stored in the three-byte area for that device, per- 
forms the required I/O function. 
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♦ A Trunk Status table is used to monitor all I/O functions that require 
servicing. The Trunk Status table is located within the boundaries of the 
IOCS and consists of one two-byte entry for each trunk. The format of 
this table is as follows: 



2 Bytes 



Address of pending 
device parameters. 



This table is created and used by the IOCS along with the left -most byte 
ofthe simultaneity indicator in the Device Parameter area. The program- 
mer need not be concerned with it. 



♦ Any of the standard 70/15 tape or card loaders can be used to load the 
IOCS and establish the Device Correspondence table. The RCA 70/15 
Binder routine can be used to consolidate (bind) the IOCS with the user 
program. The RCA 70/15 Assembler assembles the user program. The 
IOCS can be included with the programmer's source program at assembly 
time, or it can be assembled separately. 



♦ Programs that use the 70/15 IOCS can be run on a 70/25 Processor 
provided that the operating configurations are the same. However, the in- 
structions in the 70/15 IOCS required for 70/25 compatibility use approx- 
imately 65 bytes of memory. If the programmer wants to save this area, 
he removes the set of cards containing these instructions from the supplied 
IOCS source deck. These cards are clearly identified for easy removal. 
All 70/15 IOCS comments start in the same column ofthe cards. The 
compatibility cards are identified in this comments field. 



♦ The IOCS is to be maintained by the programmer in his program library 
using to 70/15 File Update routine. For updating purposes, the name of 
the IOCS is "IOCS" . 

All tags in the IOCS are four-character symbols beginning with the 
letters 10 except for the five entry (ENTRY) points. The programmer 
should avoid using such tags to prevent duplicate tags at assembly time 
if he includes the source IOCS in his source deck. 



♦ Whenever an inoperable condition code setting is detected following the 
attempted execution of any I/O instruction (Read Forward, Read Reverse, 
Read Auxiliary, Write, Write Control, Write Auxiliary) the IOCS: 

1 . Moves the actual trimk and unit number to the fixed location $P+ 5 = 
0087jg where it can be displayed by the operator. 
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2. Halts. When displayed, Halt SFj^g i^ Indicated. 

3. Re-executes the operation when the operator presses the START 
button. 

An invalid I/O operation can be generated if the programmer specifies 
a Dj^ address greater than the D2 address. In this event, the IOCS issues 
a Read Reverse instruction. 

Detection of parity errors in the reading of magnetic tape causes the 
IOCS to re-read the block. If these re-reads are imsuccessful 10 times, 
the condition is considered to be a nonrecoverable read parity error and 
control is transferred to the alarm address. 

When a read-after-write error is detected, the IOCS backspaces the 
tape one block, erases 2400 bytes (three inches of tape) and then rewrites 
the message. The procedure is repeated and if the error persists after 
10 attempts , the error is considered to be a nonrecoverable read-after- 
write error, and control is transferred to the user's alarm address. 

When the IOCS transfers control to the user's alarm address after 10 
consecutive read or write attempts on magnetic tape , the programmer is 
given the option of attempting the read or write again. 

Any time the IOCS transfers control to either the alarm address or the 
abnormal address, the user's normal return address and the address of 
the device parameters causing the transfer are undisturbed in $P. 



To aid the user programmer in the use of IOCS in the Simultaneous 
mode, three examples of suggested solutions to input/ output problems are 
given. These are: 

1. Simultaneous Input Fimctions. An explanation of an efficient 
method of performing the IN (input) function in the Simultaneous 
mode. 

2. Simultaneous Output Functions. An explanation of an efficient 
method of performing the OUT (output) function in the Simultaneous 
mode. 

3. Error Recovery on the 70/236 Card Punch. An explanation of the 
required method for error recovery on this device to maintain a 
continuous flow of processing. 
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(See Figure 2 
and Chart 2k) 



The first two examples Include a flow chart, a narrative, and the coding 
of the problem in 70/15 Assembly language. 

Note: The coding is not part of the IOCS, but is to be a part of the user 
program. Only the coding necessary to solve the general prob- 
lem is presented. Places are indicated where programmer' s 
coding to solve the programmer's specific problem can be in- 
serted. 

In the examples that follow, the identifying letters and numbers in the 
narratives refer to corresponding notation on the flow charts. 



4 The following is a recommended method and not a mandatory procedure. 
Because the 70/15 does not have base address registers or index registers, 
it is much easier to read data into one input area and move the data to a 
record area for processing rather than to use alternating input areas. 
However, specialized routines can make alternate areas more feasible. 

Block A - Represents the entrance from regular program housekeeping 
to the steps necessary to initialize the input. 

Block 10 - This fxmction initiates the first read and any re-reads caused 
by errors. Use of this method eliminates changing the simul- 
taneity indicator for first reads and re-reads. 

Block 20 - This check (CHK) function terminates the first read and suc- 
ceeding reads . This is the only point to which the IOCS returns 
other than the normal return. 

Block 30 - This end-of -input test is necessary at this point to prevent in- 
itiating another read to a device that may be inoperable because 
of an empty hopper, etc. This function can be bypassed on 
magnetic tape by use of the tape mark which would be an ab- 
normal return from the check function. 

Block kO - This move to a work area frees the input area to be used to 
read the next recoi-d. 

Block 50 - This IOCS fimction initiates the next read into the input area. 
This reading is overlapped by the processing below. 

Block 60 - This represents the programmer's coding required to process 
the data in the work area. This can include computing, output 
fimctions, or another nonsimultaneous input fimction. The 
70/15 Processor will not accept another simultaneous input 
function until the current one is processed. 

When the processing is finished, the programs should return 
to the CHK function at B. 
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TO IOCS 

(IN) 

WITH LINKAGE 




NOTE 
I THIS FUNCTION INITIATES 
I FIRST AND ANY ERROR 

READ ON THE INPUT 

DEVICE 



NOTE! 



THIS FUNCTION ERROR 
CHECKS AND TERMINATES 
I FIRST AND SUCCEEDING 
IN FUNCTIONS. IN EFFECT, 
FIRST AND ERROR READS 
/ I ARE NON-SIMO. 



NOTE I 

THIS TEST MAY BE BYPASSED 
ON DEVICES WHICH GIVE 
AN ABNORMAL RETURN 
SUCH AS TAPE MARKS. 



TO IOCS 

(CHK) 

WITH LINKAGE 



ALARM 



HALT, 
OPERATOR TO 
INTERVENTION 



70 




YES 



TERMINATE 
ROUTINE 



80 



NO 



MOVE INPUT 

TO WORK 

AREA 



40 



TO IOCS 

(IN) 

WITH LINKAGE 



NOTE 



THIS INITIATES A READ 
INTO AN INPUT AREA 
WHICH IS OVERLAPPED 
WITH THE PROCESSING 
BELOW 



PROCESS 

DATA IN 

WORK AREA 
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Figure 2. Simultaneous Input Functions, Flow Chart 
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Chart 24. Simultaneous Input Functions, Sheet 1 of 2 
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IOCS 



Simultaneous 
Output Functions 



Narrative Description 
(See Figure 3 
and Chart 25) 



^ The following is the recommended method of using the IOCS to control 
output to a buffered device. The use of simultaneity to other than a buf- 
fered device does not have any advantages, because the IOCS does not use 
the Write Auxiliary instructions. 



Block 10 



Block W - 



Block 30 
Block kO 



Represents processing. This includes receiving input data and 
processing it before preparing it in a proper format for output. 

Error checks and terminates the output function. On the first 
entry, it is a dummy, but it does not cause erroneous functions 
to be performed. It is at this point that the IOCS advises the 
using program of such items as low paper, errors, and other 
processor signals. 

This function can be bypassed if the programmer desires the 
next output function to terminate the previous output function. 
The programmer should be aware of several problems . One 
is that on an alarm or abnormal return, the IOCS has not been 
issued the output function and it is necessary to re-enter the 
routine to do this . The second problem is that if the program- 
mer wishes to substitute a magnetic tape for a buff ered device, 
the IOCS performs Rollback on the new data while destroying 
the old. 

Represents the making of a new output record. 

Initiates all output functions to the device. If step 20 is elim- 
inated, step 40 also error checks the previous function to this 
device. This I/O function is overlapped by processing. 



Block 50 - Represents abnormal returns from the IOCS for items such as 
lowpaper or sensing of a9- or 12-punch in the paper tape loop. 

Block 60 - Represents alarm conditions suchasPCE andmaybe an inter- 
pretive routine which may, for example, permit the printing of 
nonprintable characters and be a true error condition on others. 

Block 70 - Represents a step from normal processing to a terminate rou- 
tine. This leads to the final output functions. 

Block 80 - Represents the final output processing and any output functions . 

Block 90 - Represents the final check to the IOCS as this was not done in 
the above processing. 
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NOTE 
THIS REPRESENTS A 
ROUTE FROM PROCESSING 
TO A TERMINATE 
ROUTINE 
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PROCESSING 



10 



I noteI 

I — 

. THIS FUNCTION ERROR 

CHECKS PREVIOUS OUTPUT 

I FUNCTIONS TO THE DEVICE. 

I FIRST TIME THROUGH IS 

J A DUMMY FUNCTION 



ABNORMAL 
ROUTE, PAGE 
CHANGE ETC. 



50 



TO IOCS 

(CHK) 

WITH LINKAGE 



ALARM ROUTE, 
OPERATOR INTER- 
VENTION OR PRO- 
GRAM CORRECTABLE 







ARRANGE NEW 
OUTPUT 
RECORD 



30 



60. 
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NOTE 



THIS REPRESENTS 
A ROUTE TO RE- 
ISSUE THE I/O IF 
DESIRED 



TO IOCS 

(OUT) 
■ WITH LINKAGE 
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THIS FUNCTION 

INITIATES A 

WRITE TO THE 

OUTPUT DEVICE 







TERMINATION 
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PROCESSING 
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TO IOCS 

(CHK) 

WITH LINKAGE 



NOTE 
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I THIS FUNCTION ERROR 
I CHECKS THE LAST 
lOUTPUT FUNCTION 



Figure 3. Simultaneous Output Functions, Flow Chart 
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chart 25. Simultaneous Output Functions, Sheet 1 of 3 
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Error Recovery on the 
70/236 Cord Punch 



Figure 4 reveals how error recovery must be attempted on the 70/236 
Card Punch to maintain continuous flow processing. No sample coding or 
narrative description matching the flow chart is given for this example. 

Triple buffering allows error recovery from every type of punch error. 
Error recovery from a punch card error requires repunching the card in 
error plus the one just pimched, because both are routed to the reject 
stacker. This hardware scheme requires the retaining of the card image 
after it has been punched. Recovery from parity errors generated through 
transmission, or in the punch biiff er , are recovered from by repunching 
the area just punched. If there are parity errors in the buffer, the card 
in error is routed to the reject stacker. If there is a parity error in 
transmission, the punch transport does not advance. 

This routine provides for a recovery of almost any error without oper- 
ator intervention. 
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Figure 4. 70/236 Card Punch Error Recovery Procedure, Flow Chart 
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ASSEMBLER 
PROGRAM 

ASSEMBLER 
PROCESSING 



First Pass 



Second Pass 



DEVICE 

ASSIGNMENT/ 

INTERCHANGEABILITY 



♦ The 70/15 Assembly System is In the form of a classical two-pass As- 
sembler, but there is no intermediate punched output. The Assembler 
consists of two segments. Each segment processes one pass. 

♦ In the first pass , a table of name-address assignments is created. If a 
magnetic tape is selected as the input device for the second pass and the 
card reader is used as the first pass input, the cards read will be written 
to the magnetic tape, which will then be read in the second pass without 
operation or intervention. 

If a card reader is selected as the input device for the second-pass, 
the operator must restack the reader hopper with the source program 
deck. A Halt and Branch at the termination of pass one will give the oper- 
ator time to compose the second-pass input. 

♦ During the second pass the operands and operation codes are defined, 
the object program deck is generated, and the assembly listing is printed. 

♦ The input/output commands within the 70/15 Assembly System do not 
assume the use of a standard set of peripheral device trunk and unit num- 
bers. Instead, they are coded with logical device numbers and are linked 
to actual devices only at execution time. A standard function of the Loader 
performs these linkage assignments. 

A set of I/O Define cards (see "Formats", page 53), one for each logi- 
cal device required, when passed through the Loader sets up a Device 
Correspondence table which serves the I/O needs of the Assembler. These 
device assignments must be made before the Loader transfers control to the 
Assembler. Corresponding to these logical numbers the following devices 
must be defined: 

00 - Input Device for Pass 1 

01 - Input Device for Pass 2 

07 - Assembly System Device* 

08 - Object Program Output Device 

09 - Assembly Listing Device 

Since the logical device numbers do not require that a particular actual 
device (e.g. , card reader) be specified, magnetic tape may be designated 
as the actual device for any of the preceding I/O Define cards . 



*Tape Assembly. 
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Program 



GENERATED OBJECT 
PROGRAM 



Program Card 



Text Card 



Entry Card 



Extrn Card 



End Card 



ASSEMBLY LISTING 



♦ The object program generated by the 70/15 Assembly System consists 
of five types of cards. Their functional descriptions are listed below. 
(See "Formats" , page 53. ) 

♦ This card is the first card of every program. It contains the name of 
the first source statement. Its format is similar to that of a file name and, 
therefore, can serve the program as a file label on tape libraries. It also 
contains the address to which the program is assembled. This card cor- 
responds to the source START statement. 

♦ This card contains the generated object code. The text card holds ap- 
proximately 10 machine instructions along with other loader control in- 
formation such as relocation factors , memory assignment, and text card 
identification. The text card may contain partial instructions, and the 
instructions will be continued from one text card to the next. 

♦ This card corresponds to the source ENTRY statement. It contains the 
name and address of a program entry point. One object program Entry 
card is generated for each source ENTRY statement. 

♦ This card corresponds to the source EXTRN statement. It contains the 
symbolic name and address of the last program reference to the external 
name. One object program Extrn card is generated for each external name. 

♦ This card corresponds to the source END statement. It contains the 
address of the first logical instruction in the program that is to be executed. 

♦ The assembly listing contains on each line the image of the source 
language statement, the machine code that resulted from it, and the loca- 
tions assigned to each statement. In addition, the listing displays page 
headers and any necessary error flags. The source language statement 
composed almost exclusively of EBCDIC graphics is printed without edit- 
ing. Any EBCDIC nongraphic in the statement card will be represented 
as a blank. However, since each byte of machine code is probably not an 
EBCDIC graphic , the resultant machine code related to each source state- 
ment is represented on the listing in its hexadecimal form (two characters 
0-F to a byte). The address assigned to each statement, for the same 
reason, is also represented in hexadecimal form. 

The Identification field (columns 73-80) of each object program card is 
also displayed on the listing. Since one machine code Text card can be 
generated from many sequential source statements , the Text Card Identi- 
fication will be printed only with that statement that contributes the least 
significant byte of text, and indeed this byte will correspond to the address 
assigned to the statement. Because there is a one-to-one correspondence 
in a source statement and the generated object program card for the Start 
(Program), Entry (Entry), Extrn (Extrn) or End (End) card, they will al- 
ways be printed with an object program card identification. DS's generate 
no output, and, therefore, never display an Object Program Identification. 
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ASSEMBLY LISTING 
(Cont'd) 



A diagram of a page of assembly listing is shown below. 



Program Name 


70/15 Assembly Listing Date 


Page # 


1-4 7-10 


13-27 33-112 


117-120 


ef loc 


code statement 


id 



Program Name: The four-character name from the program's Start card. 



Date; 

Page # 
ef: 



loc: 



code: 



statement: 
id: 



The contents of the loader date area with slashes in- 
serted; i.e. , mm/dd/yy. 

Page count. 

Print area reserved for possible error flags. 

Up to four simultaneous error indicators can be displayed, 
one character for each error condition in the statement. 
The list of error fl^ characters and their meaning follows : 



Error Flag 

N 

O 

L 

I 

P 

U 

M 

H 

S 

T 

D 

X 

R 



Meaning 

Invalid Name 

Invalid Operation 

Invalid mask, length, trunk or unit. 

Invalid Operand 

Pimch Error During Assembly 

Undefined Symbol 

Multiple Defined Symbol 

Location Counter Overflow 

Statement Out of Order 

Name Table Overflow 

Invalid Decimal Field 

Invalid Hexadecimal Constant 

Read Error During Assembly 



Hexadecimal representation of the address assigned to 
the first byte of the statement. 

Hexadecimal representation of the coding generated by 
the statement. If more than six bytes are generated by 
a statement, a new print line is used for each additional 
six bytes or remainder. 

Image of the 80-column source statement. 

Four-character Identification field on the object program 
card associated with the statement. 
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70/15 Assembler 
Program 



RESTRICTIONS 



COMPATIBILITY 



♦ The 70/15 Assembly Program will not accept source language programs 
on magnetic tape for processing that have been blocked. If the input source 
language program is on magnetic tape , it must be inSO-byte record blocks. 

♦ The 70/15 Assembly System can be executed on the 70/25 Processor 
without any modification. A standard 70/15 loader with the compatibility 
card added must be used to load the program into the 70/25. 
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OPERATING 
PROCEDURES 

CARD SYSTEMS 



♦ In order to assemble a program using the 70/15 Assembly System, the 
operating procedures listed below must be followed. 



♦ 1. 



Compose the deck illustrated in Figure 5. If the proper loader is 
already in memory , start the deck with the four I/O Define cards . 



/&. 



70/15 Assembly 

System 

Segment 2 



/^ 



Source Progran 
Deck 



^ 



70/15 Assembly 

System 

Segment 1 



/ 



(X 



4 I/O Define 
Cards 




Figure 5. Composed Deck for Card Systems 

2. Place the composed deck in the card reader. 

3. If the loader is already in memory, this step is omitted. Insert the 

trunk and unit number of the card reader into the M register and 

depress the Load button to bring the loader into memory. The 

processor will halt with an (FF), „ in the M register. 

Id 

4. Depress the START button and the assembler will be loaded and the 
first pass will be executed. When the first pass is completed, the 
processor will halt with an (Fl) in the M register. 
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Operating 
Procedures 



CARD SYSTEMS 

(Cont'd) 



TAPE LIBRARY 
SYSTEMS 



♦ 1. 



The card reader input stacker now has segment 2 of the assembler 
ready for loading. Replace the source deck behind this segment and 
depress the START button. 



6. When pass two is completed, the processor will halt with an (FF) 
in the M register. 



16 



If the source program is on cards , compose the deck that is illus- 
trated in Figure 6. K the source program is on magnetic tape, the 
four I/O Define cards and the assembler Call card are the only re- 
quired cards. 

a 



r::^ 



Source Program 
Deck 

zz 



Assembler 
Call Card 



£2 



3 



Date Card 



^ 



ZZl 



5 I/O Define 
Card 



Figure 6. Composed Deck for Tape Library Systems (Card Output;. 

2. Place the composed deck in the card reader. 

3. If the Loader is already in memory, step 4 is omitted. 

4. If the Loader is not in memory, set the trimk and imit number of the 
Program Library Tape (PLT) into the M register and depress the 
Load button. When the Loader has been read in, the processor will 
halt with an (FF) in the M Register. 

5. Depress the START button. The four I/O define cards will be 
loaded and the Assembler call card will cause the Loader to scan 
the PLT for the Assembly Program and to subsequently load and 
execute the first pass. 

6. If the source program is on cards and the Card Reader has been 
designated as the input device for the second pass, the Processor 
will halt (Fl) at the completion of the first pass. Restack the 
source program in the Card Reader and depress the START button 
to execute the second pass. 
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Operating 
Procedure f; 



TAPE LIBRARY 
SYSTEMS (Cont'd) 



STACKED 
ASSEMBLIES 



PROGRAM HALTS 



7. If the source program is on magnetic tape, or if magnetic tape has 
been designated as the second pass input device, there is no halt 
between the first and second pass. 

8. If the object program is to be stored on tape in PLT format, the 
PLT Absolute Loader shouldbe inserted between the Assembler call 
card and the source program deck. The Assembler will write the 
loader onto the front of the object program tape. 

9. Final halt (FF) , when assembly has been completed. 

♦ Assemblies may be stacked only if the source program is on magnetic 
tape or the second pass input device is magnetic tape. In order to permit 
stacked assemblies in the PLT system, the output tapes will not be re- 
wound at the end of assembly. Rewinding can be effected by Execute cards 
placed after the last source deck. 

♦ A program halt takes place whenever a nonrecoverable error condition 
occurs. A list of halt display characters (contents of M register on con- 
sole) , their meaning and suggested operator action will be provided at a 
later date. It should be noted that source language errors will not cause 
error halts. All assemblies must be rerimfrom start if any nonrecoverable 
errors occur during assembly processing. Nonrecoverable I/O errors 
will cause the processor to halt with an(8F)j^6disP^^y6'^ i^ ^^^ ^ register. 
The trunk and device number which caused the error are stored in the 
standard location $P (Byte 130). 
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FORMATS 

I/O DEFINE CARD 
(Input) 



♦ I/O Define cards must be passed through the Loader prior to execution 
of the Assembler in order to define the peripheral devices required by the 
Assembler. Onecardis required for eachlogical device referenced by the 
Assembler. The format of the I/O Define card is as follows: 



Card 
Column 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13-80 


Legend 


V 





L 


X 


X 


A 


t 


u 


d 


d 


h 


h 


Ignored 



Note: All upper case letters must appear on the I/O Define card in 

their respective columns. 

where: VO = identification of I/O Define Card. 

L = indicates that logical device number follows. 

XX = the logical device number to which the actual device is 

assigned. The range of xx is 00 to 09. 
A = indicates that the actual trunk and device numbers follow, 
t = actual devices' trimk and may range from to 6. 
u = actual device unit and may range from to F . 
dd = the device type being defined; i.e. , 

01 = Magnetic Tape 

02 = Card Reader 

03 = Card Punch 

04 = Paper Tape Reader 

05 = Paper Tape Punch 

06 = On-Line Printer 

07 = Interrogating Typewriter 

08 = Card Reader-Pimch 

09 = Single Channel Communications 

hh = the hexadecimal representation of the control byte to be 
issued to a 7-channel magnetic tape station to set its mode 
of processing. Table 8 shows the possible hexadecimal 
representations and meanings of the control bytes. 
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Formats 



I/O DEFINE CARD 
(Cont'd) 



OBJECT PROGRAM 
CARDS (Output) 







Table 8. Control Bytes 




Binary 




Meaning 


Hexadecimal 


11110000 


800, 


odd, pack/impack on, translator off 


F0 


10110000 


556, 


odd, pack/unpack on, translator off 


B0 


01110000 


200, 


odd, pack/unpack on, translator off 


70 


11101000 


800, 


odd, pack/unpack off, translator on 


E8 


10101000 


556, 


odd, pack/unpack off, translator on 


A8 


01101000 


200, 


odd, pack/unpack off, translator on 


68 


11100000 


800, 


odd, pack/unpack off, translator off 


E0 


10100000 


556, 


odd, pack/impack off, translator off 


A0 


01100000 


200, 


odd, pack/unpack off, translator off 


60 


11001000 


800, 


even, pack/unpack off, translator on 


C8 


10001000 


556, 


even, pack/unpack off, translator on 


88 


01001000 


200, 


even, pack/unpack off, translator on 


48 


11000000 


800, 


even, pack/unpack off, translator off 


C0 


10000000 


556, 


even, pack/unpack off, translator off 


80 


01000000 


200, 


even, pack/unpack off, translator off 


40 



7 6 

1. If a control byte contains 0's in bit positions 2 and 2 , the density 

setting will not be changed from its present setting. 

4 3 

2. If a control byte contains I's in bit positions 2 and 2 , the Tape 

Controller will terminate the command. The 2^ position of the 
standard device byte will be set to 1 , and the 2" position of the 
first secondary status byte will be set to 1. This is an illegal op- 
eration. The Translator and Pack/Unpack modes may never be on 
at the same time. 

4 5 

3. If a control byte contains a 1 in position 2 and a in position 2 , 

the Tape Controller will force odd parity. If a Read command is 
attempted, and the tape was written in even parity, parity error 
will be indicated. Odd parity must be observed for pack/unpack. 

If 00 (or blanks) are specified, a 9 -channel tape station is assumed. 

♦ The object program is composed of machine language coding and Loader 
parameter cards. Five different object program formats are processed 
by the loader. Columns 1 and 2 of all five cards indicate card type. They 
are described on the following page. 
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Formats 



Program Card 



Entry Card 



Text Card 



External Card 



Card 
Column 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11-21 


22-80 


Legend 


V 


3 


n 


a 


m 


e 


a 


a 


b 


b 


date 


Ignored 



where: name 
aa 

bb 

date 



the program name. 

the EBCDIC address to which the program is 

assembled, 

the EBCDIC address of the highest bj^e +1 of this 

program. 

the contents of the date area at assembly time. 



Card 
Column 


1 


2 


3 


4 


5 


6 


7 


8 


9-80 


Legend 


V 


4 


n 


a 


m 


e 


a 


a 


Ignored 



where: name = the name of the Entry point being defined. 

aa = the EBCDIC address where it is assembled in the 

program. 



Card 

Column 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11-72 


73-80 


Legend 


V 


5 


f 


f 


f 


f 


n 


a 


a 




Text 


Ignored 



where: ffff = four EBCDIC characters corresponding to 32-float bit 
factors to be applied to the text. Each two bytes of text 
correspond to a float bit. If the bit is one, the float 
factor is added to the two bytes before transferring 
them to memory. The most significant bit corresponds 
to the most significant pair of bytes to be assembled to 
an even memory location. If the first byte of text is 
assembled to an odd location, it is not floated. 

n = the EBCDIC number of bytes of text to be transferred 
(1-62). 

aa = the address to where the first byte of text is assembled. 

Text = Generated EBCDIC Object code. 



Card 
Column 


1 


2 


3 


4 


5 


6 


7 


8 


9-80 


Legend 


V 


7 


n 


a 


m 


e 


a 


a 


Ignored 



where: n a m e = the name of the external reference. 

aa = the EBCDIC address of the assembled location of the 

last reference to external name in the program. 
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Formats 



End Card 



LOADER CALL CARD 



Card 
Column 


1 


2 


3 


4 


5 


6 


7 


8 


9-80 


Legend 


V 


9 


n 


a 


m 


e 


a 


a 


Ignored 



where: n a m e = the name of entry point to which the Loader is to 
branch. 
aa = the EBCDIC address of the assembled location to 

which the Loader is to branch. A blank in this field 
directs the Loader to issue a read of the parameter 
source. 

The following card is used to call an objectprogram from a library tape: 



Card 
Column 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15-80 


Legend 


V 


1 


n 


a 


m 


e 




h 


h 


h 


h 


i 




b 


Ignored 



where: name 
hhhh 



= is the name of the program to be loaded. 

The Assembler call name is ASTl. 
= is the hexadecimal address to where the program is 

to be loaded (031C) . 
= when nonblank signifies that the loader should not 

erase the Entry-Extrn table but continue to make 

use of it. A blank implies erasure and generation 

of a new table. 
= if nonblank it denotes PLT batched five cards/block. 
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System 73/^3 processor ^°^^ December 22, 1965 N«>- 1 

70/15 ASSEMBLY REFERENCE MANUAL #70-15-602 

First Printing April, 1965 
Revised October, 1965 

General This bulletin contains revised information to the 

70/15 Assembly System Reference Manuals • These 
changes and additions advise the reader of the latest 
information available concerning the 70/15 Assembly 
System Reference Manual. This information will be 
included in the next printing of the manual. 
Specifically, the revised information is itemized 
below. 

Pa ge Para . Line 

28 Table 4. First line. Add "(7- or 9-channel}" after 

the words "Magnetic Tape Unit". 

30 3 6, 7 Delete the sentence, "Also, all ENTRY and EXTRN... 

before assembly.". 

40 Table 5. Model number of Bill Feed Printer should 

be 70/248. 

44 Table 6. 

Card Reader: delete model number 70/232. 

Printer: change condition represented by bit position 
2^ from "Print Error" to "Channel 12 sensed." 

Change condition represented by bit position 2 from 
"Not Used" to "Channel 9 Sensed." 

Conditions represented by bit positions 2 and 2" are 
Abnormal conditions. 

Input /Output Typewriter: Model number should be 70/216, 

Magnetic Tape Devices: 

Condition represented by bit position 2 should read 
"BT/ET 
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Page Para . Line 

44 (Abnormal if read operation)." 

Bill Feed Printer: 

Model number is 70/248. 

Conditions represented by bit positions 2 and 2 
are Abnormal conditions. 

45 9 3 Change the word "END" to "EOT". 

47 6 7, 8 Change latter part of sentence to read, "... or a 

binary number that selects one of 10 loop channels 
(1-11, but not 9), depending on the setting of bit 2^." 

48 2 1 Change the first part of the sentence to read, "When 

specifying forms control through use of the OUT calling 
sequence and no pointing is desired,..." 

48 5 1 Change the first part of the sentence to read, "A check 

(CHK) is performed before the read and the 
appropriate, ..." 

48 10 1 Change first part of sentence to read, "A check (CHK) 

is performed before the read and the appropriate,.,." 

49 11 Change first part of sentence to read, "No check (CHK) 

for this read is made,,.." 

49 6 1 Change first part of sentence to read, "No check (CHK) 

for this read is performed,..." 

Delete the word "Auxiliary". 

Correct the typographical error "esires"to read "desires", 

Delete paragraph under "DEV. NO." Replace with "DEV. 
No. is actual device number (range 0-F)". 

56 5 2 Correct typographical error: 

Change "... to 70/15..." to"... the 70/15,..". 

56 6 2 Change "... five entry (ENTRY) points..." to "... seven 

seven entry (ENTRY) points...". 

56 7 3 Eliminate ", Write Auxiliary" from the list of I/O 

instructions . 



-2- 



49 


8 


4 


50 


3 


2 


52 


2 





Page Para . Line 
59 

60 



61 
62 

64 
72 
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Figure 2. Block 70. Change wording in block to read, 
"Halt, Operator intervention". 

Chart 24. Ninth line from bottom of chart — label 
field is "KEOF": insert a single quote ( ' ) in column 
22, so that the operand field is "C'$EOF'". 

Change explanation of Block 80 to read "Represents the 
final output processing and any final output functions." 

Figure 3. Block 50. Indicate that the exit from 
block 50 is to entry point C by drawing a flow line 
from block 50 to a circle containing "C". 

Chart 25. Delete top 7 comment lines. 

The following description replaces the PROGRAM HALTS 
description: 

Listing of Program Halts ♦ A program halt takes place 
whenever an error condition occurs. Following is a 
list of halt display characters (contents of M register 
on console), their meaning and suggested operator 
action. 



M Register 


Definition 


Operator Action 


00 


I/O error from logical 


Check device for 




device 00. 


inoperable con- 
dition; press 






START to retry. 


01 


I/O error from logical 


Check device for 




device 01. 


inoperable con- 
dition; press 
START to retry. 


08 


I/O error from logical 


Check device for 




device 08 


inoperable con- 
dition; press 
START to retry. 


09 


l/O error from logical 


Check device for 




device 09. 


inoperable con- 
diticn; press 
START to retry. 


BE 


Nonrecoverable l/O 


Restart assembly. 




error. 


The device number 
of the inoperable 
unit is stored in 
the standard loca- 
tion $P (Byte 
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System 70/15 Date March 25, 1966 No. 2 

70-15-602 

70/15 ASSEMBLY SYSTEM REFERENCE MANUAL 
First Printing: April, 1965 
Second Printing: October, 1965 

General This bulletin contains revised information to the 70/15 

Assembly System Reference Manual. These changes and 

additions advise the reader of the latest information 

available concerning the 70/15 Assembly System Reference 

Manual. This information will be included in the next 

printing of the manual. 
Page 

2 Under "Related Programming Systems" insert "07-Assembly 

System Device" in fifth sentence, second paragrapho 

6 Under "Additional Restrictions on Symbols" change paragraph 

3, second sentence to read" ... for a 4K processor is 80," 
Third sentence to read " »,,., for the Tape Assembly System 
is 495. 

10 Under "Character" change second sentence to read "The 

character can be any of the printable characters "» 

16 Under "Assembler Instructions" insert after last paragraph: 

"Service Routine Linkage Instructions". 

MP - Multiply 
DP - Divide 

"The Assembler will generate an actual machine instruction 
in the format of the Add Decimal (AP) instruction. The 
operation codes will be the 70/25 operation codes for MP 
and DP mnemonics. (See 70/15 Utility Routines Manual 
70-15-301)". 

17 Under "Start-Start Program (Cont'd)" second sentence of 
last paragraph delete "but is flagged as an error" « 

21 Under "Character Constants -C" add sentence to first 

paragraph. "A character constant must be a printable char- 
acter"» 
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Page 
22 



26 



Under "Hexadecimal Constants-X" change second paragraph 
to read "If the hexadecimal description specifies an 
odd number of digits, a zero digit is appended to the 
rightmost end of the constant". 

Insert after "Chart 15". 



Service Routine Linkage 
Instructions 
MP-Multiply 
DP-Divide 



The Assembler recognizes the MP 
and DP mnemonics as valid 70/15 
instructions and generates machine 
coding in the Add Decimal (APj 
format. The computer will enter 
the P2 state when the generated 
machine codes for the MP or DP 
are encountered. Servicing in 
the P2 state will be performed 
by the Multiply/Divide Service 
Routine (see the 70/15 Utility 
Routines Manual for a complete 
description of the Multiply/Divide 
Service Routine). The purpose of 
the mnemonics is to simplify the 
coding of the parameter lines 
for the Multiply/Divide Service 
Routine. The format is as follows: 



Name 

Symbol 
Symbol 



Operation 

MP 
DP 



Operand 



Sj^CLj^}, S^CL^J 



Si(Li), 



S2(L2} 



Chart 15A Example of Multiply/Divide Service Routine 
Parameter Line 



Name 



Operation 



MP 
DP 



Operand 



FOUR(2},FIVE(2} 
SIX(5),TWO(2} 



Operation 



Multiply FOUR by FIVE 
Divide SIX by TWO 
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Under "First Pass" delete all but first sentence of first 
paragraph. 

Under "Device Assignment/lnterchangeability" add sentence 
to third paragraph". "The card assembler does not provide 
Input/output control for magnetic tape". 



Page 

70 Under "Card Systems" change procedure 1 to read " 

with the five I/O Define cards. In Figure 5 change 

"4 I/O Define Cards" to read "5 l/O Define Cards". 

71 Under "Tape Library Systems" change paragraph I to read 

" five I/O Define Cards ". Change paragraph 5 to 

read "The five I/O Define Cards will be ". 

72 Under "Stacked Assemblies" delete paragraph and insert "In 
the 70/15 Tape Assembly^ provision is made to automatically 
process sequentially stacked programs. The output tapes 
will not be rewound until the assembly is terminated by 
the appearance of a $EOF c< rd. An end file tape mark will 
be written on each output tape before rewinding." 

Under "Program Halts" delete paragraph and insert the 
following : 

"A progrrim halt takes place whenever a non-recoverable error 
condition occurs. A list of halt display characters 
(Contents of M register en console;, their meaning, and 
suggested operator action ~^re listed below. It should be 
noted thrit source language errors will not cause error 
halts unless a non-printable character is encountered. 
Non-recoverable I/O errors will cause the processor to 
halt with an (SFjj^^ displayed in the M register. The 
trunk and device number which caused the error are stored 
in the standard location $P (Byte 130}". 

Card Assembly Program Halts 



Display 


Meaning 


Branch 


Action 


Chars , 








01 


READ ERROR 


Continue 


Restack card reader with error card 
followed by remainder of card 
input and depress start. 


02 


PRINT ERROR 


Continue 


Note and depress start. 


03 


PUNCH ERROR 


Continue 


Note and depress start. 


8F 


I/O INSTRUC- 


Continue 


Check inoperable condition of trunk 




TION NOT 




and unit stored at $P+5. Depress 




ACCEPTED, 




start to re-execute the operation. 


Fl 


END OF PASS I 


Continue 


Place Pass II and source program 
in card reader and depress start. 


FF 


END OF 
ASSEMBLY. 


None 


None 



- -i- 



Tape/Card Assembly Program Halts. 
PASS I 



Display 
Chars . 


Meaning 


Branch 


^ 

Action 


00 


READ ERROR 


Continue 


If card reader, restack card 
reader with error card followed 
by remainder of card input, and 
depress start. If tape, depress 
start to retry. 


01 


WRITE ERROR 
INTERMEDIATE TAPE 


Continue 


Depress start to retry write. 


08 


WRITE (PUNCH) 
ERROR OBJECT 
PROGRAM 


Continue 


Depress start to retry write 
(PUNCH J. 


09 


WRITE ERROR 
ASSEMBLY LISTING 
DEVICE 


Continue 


If tape, depress start to retry 
write. If printer, check for 
nonprintable character in 
source program card or invalid 
data in standard data area, 
make correction, and restart 
Assembly. 


8F 


I/O INSTRUCTION 
NOT ACCEPTED 


Continue 


Check inoperable condition of 
trunk and unit stored at $P+5. 
Depress start to re-execute the 
operation. 


90 


TAPE LABEL PURGE 
DATA HAS NOT BEEN 
ACCEPTED. 


Continue 


3P contains the device number. 
Depress start to override label 
check. 


BO 


$EOF STATEMENT IN 
MIDDLE OF SYM- 
BOLIC DECK. 


Continue 


Depress start to bypass $EOF 
statement . 


Fl 


END OF PASS I 


Continue 


Place Pass II and source pro- 
gram in card reader and depress 
start. 


FE 


INPUT DEVICES ARE 

IMPROPERLY 

DEFINED 


Continue 


Correct I/O define cards, reload 
card reader, and depress start. 
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Tape/ Card Assembly Program Halts (Cont'd) 
PASS II 



Display 


Meaning 


Branch 


Action 


Chars . 








01 


READ ERROR 


Continue 


If card reader, restack card reader 




SOURCE INPUT 




with error card followed by remainder 




DEVICE 




of card input and depress start. If 
tape, depress start to retry. 


08 


WRITE (PUNCH) 
ERROR OBJECT 
PROGRAM 
DEVICE 


Continue 


Depress start to retry write (PUNCH) 


, 09 


WRITE ERROR 


Continue 


If tape* depress start to retry write. 




ASSEMBLY 




If printer, check for nonprintable 




LISTING 




character in source program card, 




DEVICE 




make correction, and restart Assembly. 


8F 


I/O INSTRUC- 


Continue 


Check inoperable condition of trunk 




TION NOT 




and unit stored at $P+5. Depress 




ACCEPTED 




start to re-execute the operation. 



Page 
72 
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Replace item 7 under "Tape Library Systems" with the 
following paragraph. 

7. If the source program is on magnetic tape, there, 
is no halt between the first and second pass. If 
the source program is on cards and magnetic tape 
has been designated as the second pass input device, 
the cards read will be written to magnetic tape 
eliminating a halt between the first and second pass. 

Under "Loader Call Card" change "hhhh" definition to read 
". . . is program to be loaded (0328)". 
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System 70/15 Date September 28, 1966 No. 3 

ASSEFiBLY SYSTEM REFERENCE f^ANUAL #70-15-602 

(FIRST PRINTING: APRIL, 1965) 
(REVISED: OCTOBER, 1965) 

General: This bulletin contains revised information to the 70/15 

Assembly System Reference Manual. These changes and additions 
advise the reader of the latest information available on the 
70/15 Assembly System Reference Manual. This information will 
be included in the next printing of the manual. When required, 
subsequent bulletins may be issued to maintain the accuracy of 
the manual. The revised information is itemized below. 

Page Under Additional Restrictions on Symbols , change the third 
6 paragraph to read: 

3. The size of the source processor's main storage (4K, 
8K, or 16K) determines the maximum niomber of sjmibols 
that can be used in one program. In the Card Assembly 
System, the maximum number of symbols for a 4K pro- 
cessor is 80; maximum for an 8K processor is 700; 
maximum for a 16K processor is 2,000. In the Tape 
Assembly System, the maximum number of Symbols for an 
8K processor is 495; the maximum for a 16K processor 
is 1,860. 

7 Change the second paragraph under The Location Counter to 

read: 

The Assembler normally compiles programs for a 4K, 8K, 
or 16K memory. The location counter maintains addresses up 
to 16K. However, the Assembler flags any statement which 
sets the Location Counter above the limit stored at 148-149(2.q ) , 
The statement, nevertheless, will be processed with the excess 
Location Counter value. 

17 Change the third paragraph to read: 

If a START directive is not written as the first state- 
ment of the card assembly, the Location Counter is set to zero 
and the first statement is flagged. 
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Page 

17 (Cont'd) If a start directive is not written as the first state- 
ment of the Tape Assembly all cards will be transcribed to 
logical 08 until a START directive is encountered. The Lo- 
cation Counter is set to zero if the START directive operand 
is blank. 



